Oracle   发布时间:2022-05-17  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Oracle 11G for redhat 自启动脚本大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

Oracle 11G for redhat 自启动脚本

在$OracLE_HOME/bin中,有dbstart和dbshut这两个脚本,可以使用这两个Oracle自带的脚本实现Oracle的开机自启动。这个脚本中包含OracleListener、instance、asm instances的启动,同样dbshut也是起到关闭服务的作用。

方法一:使用/etc/rc.local系统开机启动脚本,启动Oracle

配置系统使dbstart和dbshut脚本起作用:

1)、以root编辑/etc/oratab,

orcl:/home/Oracle/app/Oracle/product/11.2.0/dbhome_1:N 这种格式,

orcl是你的oracle_sid

/home/Oracle/app/Oracle/product/11.2.0/dbhome_1是OracLE_HOME,

这里需要把N改为Y,即orcl:/home/Oracle/app/Oracle/product/11.2.0/dbhome_1:Y。

2)、以Oracle编辑$OracLE_HOME/bin/dbstart,找到其中第78行:OracLE_HOME_ListNER=改为你自己的路径,或者可以改成OracLE_HOME_ListNER=$OracLE_HOME

保存脚本,以Oracle用户运行dbshut和dbstart看是否能关闭、启动数据库。如果不能,一般是参数设置,根据报错找到对应位置更改。

经过上一步的配置,可以直接用dbstart命令启动数据Listener、instance、asm instances,但是@R_631_9036@Oracle10g的EM,OracLE利用web页面管理数据库相当方便,也是10g的一个特色,所以应该一并启动起该服务来。

$OracLE_HOME/bin/emctl start dbconsole

因此我们可以用rc.local或者redhat服务都可以实现要求的开机启动。下面分别说一下:

1)、利用rc.local。直接把dbstart加到rc.local中,实现开机自动启动。这里需要注意的是必须以Oracle启动该脚本。

用root编辑/etc/rc.local,添加下面三行:

su Oracle –lc "/home/Oracle/app/Oracle/product/11.2.0/dbhome_1/bin/@R_489_1822@"

su - Oracle -c "/home/Oracle/app/Oracle/product/11.2.0/dbhome_1/bin/dbstart"

su - Oracle -c "/u01/product/10.2.0/db_1/bin/emctl start dbconsole"

这里"/home/Oracle/app/Oracle/product/11.2.0/dbhome_1需要替换成实际的OracLE_HOME

保存并退出后,reboot服务器测试一下,可以看到,当系统启动以后Oracle监听、实例和em都已经起来了

方法二:使用/etc/rc.d/init.d/Oracle 自创脚本启动关闭数据库

如果我们不用rc.local,也可以加到redhat服务中。在/etc/rc.d/init.d中添加如下脚本文件,命名为Oracle:

#!/bin/sh

#chkconfig: 2345 99 01

#description: OracLE 10g Server

OracLE_HOME=/u01/product/10.2.0/db_1

if [ ! -f $OracLE_HOME/bin/dbstart ]

then

echo "OracLE cAnnot start"

exit

fi

case "$1" in

'start')

echo "StarTing Oracle Database..."

su - Oracle -c "$OracLE_HOME/bin/dbstart"

su - Oracle -c "$OracLE_HOME/bin/emctl start dbconsole"

;;

'stop')

echo "StoPing Oracle Database"

su - Oracle -c "$OracLE_HOME/bin/emctl stop dbconsole"

su - Oracle -c "$OracLE_HOME/bin/dbshut"

;;

esac

注意其中两行注释,网上很多脚本因为少了这两行不能使服务自启动:

#chkconfig: 2345 99 01

#description: OracLE 10g Server

其中chkconfig:2345 99 01 是指脚本将为运行级2、3、4、5启动Oracle 10g服务,启动优先级为99,关闭优先级为01。

然后以root权限:

# mv Oracle /etc/init.d

# chkconfig --add Oracle

# chkconfig --List Oracle 查看,这样的话就把OracLE就可以开机启动和关机前shutdown immediate

重启系统,就可以在启动的过程中看到 StarTing Oracle ,因为我们设置的优先级为99,一般是最后启动。[OK]以后就可以了。因为要启动emctl,可能有点慢,等待的时间要稍微长一点。

启动以后可以以root执行Oracle start或者Oracle stop来启动或停止服务

总结:我是采用方式一进行实现的,方法二没有经过测试

转载请注明:http://blog.163.com/nocturnal_ken/blog/static/17802332720111945726777/

大佬总结

以上是大佬教程为你收集整理的Oracle 11G for redhat 自启动脚本全部内容,希望文章能够帮你解决Oracle 11G for redhat 自启动脚本所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:启动