通过脚本实现Linux Oracle服务机自启动

23 篇文章 1 订阅
  1. 以root身份登录到linux系统,编辑/etc/oratab文件,找到
orcl:/u01/app/oracle/product/11.2.0/db_1:N
//改为
orcl:/u01/app/oracle/product/11.2.0/db_1:Y

在这里插入图片描述
2. 修改dbstart和dbshut启动关闭脚本,使其启动数据库的同时也自动启动监听器(即启动数据库时启动监听器,停止数据库时停止监听器):

# vim /u01/app/oracle/product/11.2.0/db_1/bin/dbstart
# 找到下面的代码:
ORACLE_HOME_LISTNER=$1
# 将其改为
ORACLE_HOME_LISTNER=$ORACLE_HOME

在这里插入图片描述
同样也修改dbshut脚本:

# vim /u01/app/oracle/product/12.1.0/dbhome_1/bin/dbshut
# 找到下面的代码: 
ORACLE_HOME_LISTNER=$1 
# 将其改为 
ORACLE_HOME_LISTNER=$ORACLE_HOME
  1. 配置/etc/rc.d/rc.local,添加以下脚本:
su oracle -lc "/u01/app/oracle/product/11.2.0/db_1/bin/lsnrctl start"
su oracle -lc /u01/app/oracle/product/11.2.0/db_1/bin/dbstart
  1. 在/etc/init.d创建oracle服务启动,注意修改oracle路径:
#!/bin/sh
# chkconfig: 345 61 61
# description: Oracle 11g R2 AutoRun Servimces
# /etc/init.d/oracle
#
# Run-level Startup script for the Oracle Instance, Listener, and
# Web Interface
export ORACLE_BASE=/u01/app/oracle   
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1   #根据个人情况修改路径
export ORACLE_SID=orcl            #数据库实例ORACLE_SID
export PATH=$PATH:$ORACLE_HOME/bin
ORA_OWNR="oracle"
# if the executables do not exist -- display error
if [ ! -f $ORACLE_HOME/bin/dbstart -o ! -d $ORACLE_HOME ]
	then
		echo "Oracle startup: cannot start"
	exit 1
fi
# depending on parameter -- startup, shutdown, restart
# of the instance and listener or usage display
case "$1" in
start)
# Oracle listener and instance startup
su $ORA_OWNR -lc $ORACLE_HOME/bin/dbstart
echo "Oracle Start Succesful!OK."
;;
stop)
# Oracle listener and instance shutdown
su $ORA_OWNR -lc $ORACLE_HOME/bin/dbshut
echo "Oracle Stop Succesful!OK."
;;
reload|restart)
$0 stop
$0 start
;;
*)
echo $"Usage: `basename $0` {start|stop|reload|reload}"
exit 1
esac
exit 0
  1. 改变文件权限
 chmod 755 /etc/init.d/oracle
  1. 添加服务
chkconfig --level 35 oracle on
  1. 使用方法
service oracle start        //启动oracle
service oracle stop        //关闭oracle
service oracle restart     //重启oracle
  1. 测试
    重启系统
shutdown -r now

测试服务

`lsnrctl status   //实例
ps -ef | grep ora_ | grep -v grep   //实例进程

`

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值