備注:此文根據(jù)網(wǎng)上文章實踐并修改所成。
網(wǎng)站建設哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、小程序設計、集團企業(yè)網(wǎng)站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了尖扎免費建站歡迎大家使用!
RHEL6.8 64bit+Oracle Database 11g Enterprise Edition Release 11.2.0.1.0
Oracle 11g系統(tǒng)自動啟動與關閉的設置方法
第一步:要在Linux中設置允許ORACLE系統(tǒng)自動啟動,因為默認情況下是設置為不允許的。
1.root賬戶下修改/etc/oratab文件:
# vi /etc/oratab
找到:orcl=/db/app/oracle/product/11.1.0/db_1 :N
改為:orcl=/db/app/oracle/product/11.1.0/db_1 :Y
就是將最后的N改為Y,將不允許自動啟動改為允許自動啟動。
2.修改Oracle自帶的啟動與關閉腳本,分別是dbstart和dbshut;
執(zhí)行這兩個腳本就可以實現(xiàn)ORACLE腳本的啟動與關閉。
在oracle賬戶下修改$ORACLE_HOME/bin/dbstart文件:
$ vi $ORACLE_HOME/bin dbstart
找到: ORACLE_HOME_LISTNER=$1
改為:ORACLE_HOME_LISTNER=$ORACLE_HOME
之所以做這一步,是因為在這個腳本自動生成的時候,也就是Oracle被安裝進Linux的時候,這個腳本并不知道你的ORACLE_HOME_LISTNER是什么,現(xiàn)在安裝后要將這個參數(shù)顯示的寫明,這樣就不會在執(zhí)行這個腳本的時候報出ORACLE_HOME_LISTNER沒有被指定的錯誤了。
注意:dbstart和dbshut腳本在10g版本之后,已經(jīng)將監(jiān)聽器的啟動與關閉合并進數(shù)據(jù)庫實例的啟動與關閉腳本里面了,而不再是單獨分開的了。
同樣的方式,也要修改dbshut的這個參數(shù)。這里就不再詳細寫出了,腳本在同一個目錄下。
第二步:寫一個腳本,把它注冊為一個系統(tǒng)服務,讓它在開機與關機的時候運行。它的作用就是調用并執(zhí)行dbstart和dbshut。這樣不就實現(xiàn)了數(shù)據(jù)庫啟動與關閉了。
1.創(chuàng)建腳本名為oracle,腳本被放在/etc/init.d目錄中。
腳本代碼如下:
#!/bin/bash
# chkconfig: 2345 96 11
# description:Startup Script for oracle Databases
#/etc/rc.d/init.d/oradbstart
exportORACLE_BASE=/u01/app/oracle/
export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1
exportORACLE_SID=ORDB
exportPATH=$PATH:$ORACLE_HOME/bin
case "$1"in
start)
echo"-----startup oracle-----">> /var/log/oraclelog
su - oracle -c"$ORACLE_HOME/bin/dbstart"
touch /var/lock/subsys/oracle
echo"-----startup oracle successful-----">> /var/log/oraclelog
echo "OK"
;;
stop)
echo"-----shutdwn oracle-----">> /var/log/oraclelog
su - oracle -c"$ORACLE_HOME/bin/dbshut"
rm -f /var/lock/subsys/oracle
echo"-----shutdown oracle successful-----">> /var/log/oraclelog
echo "OK"
;;
reload|restart)
$0 stop
$1 start
;;
*)
echo "Usage:'basename $0' start|stop|reload|restart"
exit 1
esac
exit 0
保存內容并退出。
現(xiàn)在,我要對這段腳本做一個關鍵解釋:
第一:# chkconfig: 2345 99 10 雖是一行注釋,但是確實關鍵的必不可少的一行,除非你不用chkconfig命令來自動生成符號連接文件,而是完全采用手工創(chuàng)建。否則沒有這一行,執(zhí)行chkconfig系統(tǒng)將會報出oracle沒有chkconfig服務權限的錯誤。
第二:su - oracle -c $ORACLE_HOME/bin/dbstart和touch /var/lock/subsys/oracle這兩行的作用是首先執(zhí)行dbstart腳本啟動oracle,然后在服務活動列表目錄中創(chuàng)建一個與oracle這個服務同名的一個文件,表示這個服務是活動的,也就是被啟動的。
第三:su - oracle -c $ORACLE_HOME/bin/dbshut 和rm -f /var/lock/subsys/oracle這兩行的作用是首先執(zhí)行dbshut腳本關閉oracle,然后從服務活動列表目錄中刪除那個與oracle同名的那個文件,表示這個服務不是活動的,也就是已經(jīng)被關閉。
那么為什么要做touch /var/lock/subsys/oracle和rm -f /var/lock/subsys/oracle這兩步呢?原因是跟Linux系統(tǒng)的機制有關的:Linux的判別一個服務是否被啟動的依據(jù)是在/var/lock/subsys/目錄下是否有與服務名相同的文件,若有則表示這個服務已經(jīng)被啟動了,在系統(tǒng)關閉的時候,Linux會把這里面列出的服務全部關閉,并刪掉與服務同名的文件。若一個服務被啟動了,但卻在這個目錄里沒有那個服務的同名文件,則不會關閉那個服務。
網(wǎng)上的文章均將這個地方設置錯了,所以會發(fā)現(xiàn),Oracle可以隨系統(tǒng)啟動了,但卻沒有隨系統(tǒng)關閉。
分析了/etc/rc.d/rc.local后才發(fā)現(xiàn)這個原理的。
經(jīng)過試驗,果然如此。再分析MySQL的啟動與關閉腳本也是這樣做的,最終恍然大悟。原來如此。這個地方請大家注意了。
最后,就是將這個腳本注冊成為一個系統(tǒng)服務就可以了,方法有二:
其一:先給腳本分配可以被執(zhí)行的權限。執(zhí)行下面命令:
代碼如下:
#su - root
chown oracle /etc/init.d/oracle
chmod 775 /etc/init.d/oracle
再創(chuàng)建符號鏈接文件。
chkconfig --add /etc/init.d/oracle,執(zhí)行這個命令就需要你在腳本中寫上
# chkconfig: 2345 99 10 了。這樣當這個命令被執(zhí)行的時候,會去oracle文件中尋找這行注釋,并解析這行注釋,根據(jù)解析結果分別在/etc/rc.d/rc2.d;/etc/rc.d/rc3.d;/etc/rc.d/rc4.d;/etc/rc.d/rc5.d中創(chuàng)建符號連接文件S99oracle文件,這個文件是系統(tǒng)啟動時要執(zhí)行的,其實這個文件是指向/etc/init.d/oracle的,啟動的時候系統(tǒng)向這個文件發(fā)送一個start參數(shù),也就執(zhí)行了oracle文件中的start分支了。
另外還會在/etc/rc.d/rc0.d;/etc/rc.d/rc1.d;/etc/rc.d/rc6.d中創(chuàng)建K10oracle文件,這個文件時系統(tǒng)關閉時要執(zhí)行的,其實這個文件也是指向/etc/init.d/oracle的,關閉的時候系統(tǒng)向這個文件發(fā)送一個stop參數(shù),也就執(zhí)行了oracle文件中的stop分支了。
我想你應該明白# chkconfig: 2345 99 10 中這些數(shù)字的含義了吧:
指出2,3,4,5級別啟動這個服務,99是在相應的/etc/rc.d/rcN.d(N為前面指定的級別,這里是2345)目錄下生成的鏈接文件的序號(啟動優(yōu)先級別)S99oracle,10為在除前面指出的級別對應的/etc/rc.d/rcN.d(N為除2345之外的級別)目錄生成的鏈接文件的序號(服務停止的優(yōu)先級別)K10oracle。至于為什么在這些目錄中創(chuàng)建文件和文件的命名規(guī)則,這就要您對Linux的系統(tǒng)啟動流程有一個熟悉的了解了,在這就不詳談了。
其二:若您想嘗試一下手動創(chuàng)建符號連接文件的樂趣,請執(zhí)行如下命令:
代碼如下:
#su - root
ln -s /etc/init.d/oracle/etc/rc.d/rc2.d/S99oracle
ln -s /etc/init.d/oracle/etc/rc.d/rc3.d/S99oracle
ln -s /etc/init.d/oracle/etc/rc.d/rc4.d/S99oracle
ln -s /etc/init.d/oracle/etc/rc.d/rc5.d/S99oracle
ln -s /etc/init.d/oracle/etc/rc.d/rc0.d/K10oracle
ln -s /etc/init.d/oracle/etc/rc.d/rc1.d/K10oracle
ln -s /etc/init.d/oracle/etc/rc.d/rc6.d/K10oracle
其實手動這樣操作作用效果和執(zhí)行chkconfig --add oracle是一樣的。
到此,所有設置就完成了,下面進行一下測試:
#cd /etc/init.d
sh oracle start 或者service oracle start
執(zhí)行后,看看/var/log目錄下的oraclelog文件,里面是不是有腳本的啟動分支輸出信息呢?
sh oracle stop或者service oracle stop
執(zhí)行后,看看/var/log目錄下的oraclelog文件,里面是不是有腳本的關閉分支輸出信息呢?
若看到信息,表示您設置成功了。若沒有,請再仔細設置一遍,并注意文件的權限問題。
當前標題:Oracle11g數(shù)據(jù)庫隨系統(tǒng)自動啟動與關閉的設置方法
鏈接URL:http://vcdvsql.cn/article48/gdjohp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供App設計、標簽優(yōu)化、用戶體驗、移動網(wǎng)站建設、網(wǎng)站改版、域名注冊
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)