欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ORACLE11g隨RHEL5系統(tǒng)自動啟動與關閉的設置方法

 更新時間:2009年08月30日 22:32:27   作者:  
最近,ORACLE系統(tǒng)基本調(diào)試通過,是時候設置ORACLE隨RHEL自動啟動與關閉服務的時候了,之所以把這個任務放在最后來做,是因為我覺得這個應該不會很難,但真正實施起來,還是遇到了個不小的障礙
寫好腳本,注冊好服務之后,經(jīng)測試,ORACLE可以隨RHEL啟動而啟動,但不能隨系統(tǒng)關閉而關閉。在網(wǎng)上找答案,發(fā)現(xiàn)幾乎所有的設置過程帖子都是從同一篇原樣照抄過來的,根本就行不通。天下文章一大抄。求助他人,沒有得到一個好的解決方案。無奈,自己靜下心來慢慢研究分析,總算找到了問題的關鍵原因所在。
現(xiàn)在就把我的整個成功設置的過程貼出來,供大家參考,以期大家能少走彎路;另外還是要給其他人一個建議:切莫生硬照搬,斷章取義,否則其害大焉?。?
首先,要在RHEL中設置允許ORACLE系統(tǒng)自動啟動,因為默認情況下是設置為不允許的。操作如下:
在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,意思是將不允許自動啟動改為允許自動啟動。
然后,是修改ORACLE自帶的啟動與關閉腳本,分別是dbstart和dbshut。執(zhí)行這兩個腳本就可以實現(xiàn)ORACLE腳本的啟動與關閉。
在oracle賬戶下修改$ORACLE_HOME/bin/dbstart文件:
復制代碼 代碼如下:

# su - ORACLE
$ cd $ORACLE_HOME/bin
$ vi dbstart

找到 ORACLE_HOME_LISTNER=$1這一行
改為:
ORACLE_HOME_LISTNER=$ORACLE_HOME
之所以做這一步,是因為在這個腳本自動生成的時候,也就是ORACLE被安裝進RHEL的時候,這個腳本并不知道你的
ORACLE_HOME_LISTNER是什么,現(xiàn)在要將這個參數(shù)顯示的寫明,這樣就不會在執(zhí)行這個腳本的時候報
ORACLE_HOME_LISTNER沒有被指定的錯誤了。注意:dbstart和dbshut腳本在10g之后就已經(jīng)將監(jiān)聽器的啟動與關閉合并進數(shù)
據(jù)庫實例的啟動與關閉腳本里面了。而不再是單獨分開的了。
同樣的方式,我們也要修改dbshut的這個參數(shù)。這里就不再詳細寫出了,他們在同一個目錄下。
再次,就是寫一個腳本,把它注冊為一個系統(tǒng)服務,讓它在開機與關機的時候運行。它的作用就是調(diào)用并執(zhí)行dbstart和dbshut。這樣不
就實現(xiàn)了數(shù)據(jù)庫啟動與關閉了嗎?!這個腳本被放在/etc/init.d目錄中,腳本的名字是oracle11
腳本如下:
復制代碼 代碼如下:

#!/bin/bash
# chkconfig: 2345 99 10
# description: Startup Script for oracle Databases
# /etc/rc.d/init.d/oradbstart
export ORACLE_BASE=/db/app/oracle/
export ORACLE_HOME=/db/app/oracle/product/11.1.0/db_1
export ORACLE_SID=orcl
export PATH=$PATH:$ORACLE_HOME/bin
case "$1" in
start)
echo "-----startup oracle-----" >> /var/log/oracle11log
su oracle -c $ORACLE_HOME/bin/dbstart
touch /var/lock/subsys/oracle11
echo "-----startup oracle successful-----" >> /var/log/oracle11log
echo "OK"

stop)
echo "-----shutdwn oracle-----" >> /var/log/oracle11log
su oracle -c $ORACLE_HOME/bin/dbshut
rm -f /var/lock/subsys/oracle11
echo "-----shutdown oracle successful-----" >> /var/log/oracle11log
echo "OK"

*)
echo "Usage: 'basename $0' start|stop"
exit 1
esac
exit 0

保存并退出。
現(xiàn)在,我要對這段腳本做一個關鍵解釋:
第一:# chkconfig: 2345 99 10 雖是一行注釋,但是確實關鍵的必不可少的一行,除非你不用chkconfig命令來自動生成符號連接文件,而是完全采用手工創(chuàng)建。否則沒有這一行,執(zhí)行chkconfig系統(tǒng)將會報出oracle11沒有chkconfig服務權限的錯誤。
第二:su oracle -c $ORACLE_HOME/bin/dbstart 和touch /var/lock/subsys/oracle11這兩行的作用是首先執(zhí)行dbstart腳本啟動oracle,然后在服務活動列表目錄中創(chuàng)建一個與oracle11這個服務同名的一個文件,表示這個服務是活動的,也就是被啟動的。
而su oracle -c $ORACLE_HOME/bin/dbshut 和rm -f /var/lock/subsys/oracle11這兩行的作用是首先執(zhí)行dbshut急哦腳本關閉oracle,然后從服務活動列表目錄中刪除那個與oracle11同名的那個文件,表示這個服務不是活動的,也就是已經(jīng)被關閉。
那么為什么要做touch /var/lock/subsys/oracle11和rm -f /var/lock/subsys/oracle11這兩步呢?原因是跟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/oracle11
chmod 775 /etc/init.d/oracle11

再創(chuàng)建符號鏈接文件。
chkconfig --add /etc/init.d/oracle11,執(zhí)行這個命令就需要你在腳本中寫上# chkconfig: 2345 99 10 了。這樣當這個命令被執(zhí)行的時候,回去oracle11文件中尋找這行注釋,并解析這行注釋,根據(jù)解析結果分別在/etc/rc.d/rc2.d;/etc/rc.d/rc3.d;/etc/rc.d/rc4.d;/etc/rc.d/rc5.d中創(chuàng)建符號連接文件S99oracle11文件,這個文件是系統(tǒng)啟動時要執(zhí)行的,其實這個文件是指向/etc/init.d/oracle11的,啟動的時候系統(tǒng)向這個文件發(fā)送一個start參數(shù),也就執(zhí)行了oracle11文件中的start分支了。還會在/etc/rc.d/rc0.d;/etc/rc.d/rc1.d;/etc/rc.d/rc6.d中創(chuàng)建K10oracle11文件,這個文件時系統(tǒng)關閉時要執(zhí)行的,其實這個文件也是指向/etc/init.d/oracle11的,關閉的時候系統(tǒng)向這個文件發(fā)送一個stop參數(shù),也就執(zhí)行了oracle11文件中的stop分支了。
我想你應該明白# chkconfig: 2345 99 10 中這些數(shù)字的含義了吧:指出2,3,4,5級別啟動這個服務,99是在相應的/etc/rc.d/rcN.d(N為前面指定的級別,這里是2345)目錄下生成的鏈接文件的序號(啟動優(yōu)先級別)S99oracle11,10為在除前面指出的級別對應的/etc/rc.d/rcN.d(N為除2345之外的級別)目錄生成的鏈接文件的序號(服務停止的優(yōu)先級別)K10oracle11。至于為什么在這些目錄中創(chuàng)建文件和文件的命名規(guī)則,這就要您對LINUX的系統(tǒng)啟動流程有一個熟悉的了解了,在這就不詳談了。
其二:若您想嘗試一下手動創(chuàng)建符號連接文件的樂趣,請執(zhí)行如下命令:
復制代碼 代碼如下:

#su - root
ln -s /etc/init.d/oracle11 /etc/rc.d/rc2.d/S99oracle11
ln -s /etc/init.d/oracle11 /etc/rc.d/rc3.d/S99oracle11
ln -s /etc/init.d/oracle11 /etc/rc.d/rc4.d/S99oracle11
ln -s /etc/init.d/oracle11 /etc/rc.d/rc5.d/S99oracle11
ln -s /etc/init.d/oracle11 /etc/rc.d/rc0.d/K10oracle11
ln -s /etc/init.d/oracle11 /etc/rc.d/rc1.d/K10oracle11
ln -s /etc/init.d/oracle11 /etc/rc.d/rc6.d/K10oracle11

作用效果和執(zhí)行chkconfig --add oracle11是一樣的。
到此,所以得設置過程就結束了,下面進行一下測試吧:
復制代碼 代碼如下:

#cd /etc/init.d
sh oracle11 start

執(zhí)行后,看看/var/log目錄下的oracle11log文件,里面是不是有腳本的啟動分支輸出信息呢?
sh oracle11 stop
執(zhí)行后,看看/var/log目錄下的oracle11log文件,里面是不是有腳本的關閉分支輸出信息呢?
若看到信息,表示您設置成功了。若沒有,請再仔細設置一遍,并注意文件的權限問題。LINUX的用戶概念是很嚴格的。畢竟是多用戶系統(tǒng)嘛。
文章屬于作者原創(chuàng),轉載請注明出處。
來自:http://blog.csdn.net/kanon_lgt/

相關文章

  • oracle數(shù)據(jù)庫在客戶端建立dblink語法

    oracle數(shù)據(jù)庫在客戶端建立dblink語法

    oracle服務器沒有建立目標數(shù)據(jù)庫的TNS時,在客戶端(有權限的情況下)建立dblink語法如下,有需求的朋友可以參考下哈
    2013-05-05
  • oracle中函數(shù) trunc(),round(),ceil(),floor的使用詳解

    oracle中函數(shù) trunc(),round(),ceil(),floor的使用詳解

    這篇文章主要介紹了oracle中函數(shù) trunc(),round(),ceil(),floor的使用詳解的相關資料,需要的朋友可以參考下
    2017-03-03
  • Oracle報錯ora-12514檢查以及解決方法

    Oracle報錯ora-12514檢查以及解決方法

    前幾天重新安裝了數(shù)據(jù)庫服務器,在服務器上使用都一切正常,然后在我的客戶端配置一個tns服務名卻出問題了,下面這篇文章主要給大家介紹了關于Oracle報錯ora-12514檢查以及解決方法的相關資料,需要的朋友可以參考下
    2023-03-03
  • 關于expdp任務異常的處理案例詳析

    關于expdp任務異常的處理案例詳析

    這篇文章主要給大家介紹了關于expdp任務異常處理的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • Oracle監(jiān)聽器服務不能啟動的解決方法

    Oracle監(jiān)聽器服務不能啟動的解決方法

    這篇文章主要介紹了Oracle監(jiān)聽器服務不能啟動的解決方法,需要的朋友可以參考下
    2014-07-07
  • VMware中l(wèi)inux環(huán)境下oracle安裝圖文教程(一)

    VMware中l(wèi)inux環(huán)境下oracle安裝圖文教程(一)

    剛剛接觸ORACLE的人來說,從那里學,如何學,有那些工具可以使用,應該執(zhí)行什么操作,一定回感到無助。所以在學習使用ORACLE之前,首先來安裝一下ORACLE 10g,在來掌握其基本工具。俗話說的好:工欲善其事,必先利其器。作為一個新手,我們還是先在VMware虛擬機里安裝吧。
    2014-08-08
  • Oracle數(shù)據(jù)庫如何使用exp和imp方式導數(shù)據(jù)

    Oracle數(shù)據(jù)庫如何使用exp和imp方式導數(shù)據(jù)

    在平時的工作中,我們難免會遇到要備份數(shù)據(jù),當然用pl/sql可以實現(xiàn)通過導出數(shù)據(jù)來備份數(shù)據(jù),下面這篇文章主要給大家介紹了關于Oracle數(shù)據(jù)庫如何使用exp和imp方式導數(shù)據(jù)的相關資料,需要的朋友可以參考下
    2022-06-06
  • plsql配置tnsnames.ora的實現(xiàn)方法

    plsql配置tnsnames.ora的實現(xiàn)方法

    這篇文章主要介紹了plsql配置tnsnames.ora的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • 在Tomcat服務器下使用連接池連接Oracle數(shù)據(jù)庫

    在Tomcat服務器下使用連接池連接Oracle數(shù)據(jù)庫

    本文為大家介紹下在Tomcat服務器下使用連接池來連接數(shù)據(jù)庫的操作,下面有個不錯的示例,大家可以參考下
    2014-01-01
  • Linux 自動備份oracle數(shù)據(jù)庫詳解

    Linux 自動備份oracle數(shù)據(jù)庫詳解

    這篇文章主要介紹了Linux 自動備份oracle數(shù)據(jù)庫詳解方法的相關資料,數(shù)據(jù)庫的備份的重要性,不言而喻,希望能幫到大家,需要的朋友可以參考下
    2016-10-10

最新評論