Oracle在linux下的開機自啓動(詳細)

linux下系統開機oracle自啓動(方法一) ---加載爲服務自啓動、停止
一、dbstart   及   dbstop   

Oracle   數據庫的自動啓動及停止可籍   Oracle   提供的   dbstart   及   dbshut   檔達成   (在   7.3.3.0.0   中)。這些文件又耍依靠   /etc/oratab   存在才能使用(雖然更改   dbshut   和   dbstart   檔可使解除這限制。)    
   
/etc/oratab   檔格式如下:    
--------------------------------------------------------------------------------  
SID:ORACLE_HOME:AUTO  
--------------------------------------------------------------------------------
例如
--------------------------------------------------------------------------------
   
*:/opt/oracle9/product/9.2.0.4:N
boss:/opt/oracle9/product/9.2.0.4:Y

--------------------------------------------------------------------------------  
   
二、 init.d   及   rc.d   

要在開機關機時自動啓動和結束數據庫的話,你需要修改   Linux   的啓動腳本文件。這並不困難,不過,我需要指出這些改動因應不同的   Linux   發行版本(slackware,   debian,   redhat   等)而有所不同。我這些例子適用於   Redhat   5.0。要爲你所用的   Linux   作出修改,請先參考你手頭上的   Linux   文件。(雖然這實際上應該適用於所有   Sys   V   UNIX。)    
   
首先,我們要建立會執行   /etc/rc.d/init.d   目錄中   dbshut   及   dbstart   的腳本文件。把以下文件命名爲   /etc/rc.d/init.d/oracle:    
 
#############################################################

#chkconfig:2345 98 05
#description:Oracle Server

#add for oracle
ORACLE_BASE=/opt/oracle9
export ORACLE_BASE
ORACLE_HOME=$ORACLE_BASE/product/9.2.0.4
export ORACLE_HOME
ORACLE_SID=BOSS
export ORACLE_SID
ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data
export ORA_NLS33
NLS_LANG=american_america.zhs16gbk
export NLS_LANG
LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib
export LD_LIBRARY_PATH

case "$1" in
        start)
                echo "Starting Oracle..."
                su oracle -c "/opt/oracle9/product/9.2.0.4/bin/lsnrctl start"
                su oracle -c "/opt/oracle9/product/9.2.0.4/bin/dbstart 1>$ORACLE_HOME/bin/dbstart.log  2>$ORACLE_HOME/bin/dbstart.err"
                echo "Started."
exit 0
;;
        stop)
                echo "Stoping Oracle..."
                su oracle -c "/opt/oracle9/product/9.2.0.4/bin/lsnrctl stop"
                su oracle -c "/opt/oracle9/product/9.2.0.4/bin/dbshut"
                echo "Stoped."
exit 0
;;

*)
echo "Usage: $0 {start|stop}"
exit 1

esac 


#############################################################


下面是另一SHELL的
--------------------------------------------------------------------------------  
   
#!/bin/sh  
#  
#chkconfig:2345 98 05
#description:Oracle Server
#/etc/rc.d/init.d/oracle  
#解說∶啓動及停止   Oracle   數據庫和監聽程序  
#檢查如何執行腳本文件  
case   "$1"   in  
      start)  
                  echo   -n   "Starting   Oracle   Databases:   "  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  date   +"!   %T   %a   %D   :   Starting   Oracle   Databases   as   part   of   system   up."   >>   /var/log/oracle  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  su   -   oracle   -c   dbstart   >>   /var/log/oracle  
                  echo   "Done."  
                  echo   -n   "Starting   Oracle   Listeners:   "  
                  su   -   oracle   -c   "lsnrctl   start"   >>   /var/log/oracle  
                  echo   "Done."  
                  echo   ""  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  date   +"!   %T   %a   %D   :   Finished."   >>   /var/log/oracle  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  touch   /var/lock/subsys/oracle  
                  ;;  
      stop)  
                  echo   -n   "Shutting   Down   Oracle   Listeners:   "  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  date   +"!   %T   %a   %D   :   Shutting   Down   Oracle   Databases   as   part   of   system   down."   >>   /var/log/oracle  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  su   -   oracle   -c   "lsnrctl   stop"   >>   /var/log/oracle  
                  echo   "Done."  
                  rm   -f   /var/lock/subsys/oracle  
                  echo   -n   "Shutting   Down   Oracle   Databases:   "  
                  su   -   oracle   -c   dbshut   >>   /var/log/oracle  
                  echo   "Done."  
                  echo   ""  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  date   +"!   %T   %a   %D   :   Finished."   >>   /var/log/oracle  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  ;;  
      restart)  
                  echo   -n   "Restarting   Oracle   Databases:   "  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  date   +"!   %T   %a   %D   :   Restarting   Oracle   Databases   as   part   of   system   up."   >>   /var/log/oracle  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  su   -   oracle   -c   dbstop   >>   /var/log/oracle  
                  su   -   oracle   -c   dbstart   >>   /var/log/oracle  
                  echo   "Done."  
                  echo   -n   "Restarting   Oracle   Listeners:   "  
                  su   -   oracle   -c   "lsnrctl   stop"   >>   /var/log/oracle  
                  su   -   oracle   -c   "lsnrctl   start"   >>   /var/log/oracle  
                  echo   "Done."  
                  echo   ""  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  date   +"!   %T   %a   %D   :   Finished."   >>   /var/log/oracle  
                  echo   "----------------------------------------------------"   >>   /var/log/oracle  
                  touch   /var/lock/subsys/oracle  
                  ;;  
      *)  
                  echo   "Usage:   oracle   {start|stop|restart}"  
                  exit   1  
esac  
   
   
   
不要吝嗇於檢查這個文件到底有沒有真的正確地啓動和停止系統中的數據庫。請檢查記錄檔(log   file),看看有沒有錯誤訊息。    
弄妥這腳本文件後,我們要在正確的執行等級目錄   (runlevel   directories)   /etc/rc.d/rcX.d   中建立及刪除符號連結   (symbolic   links)。    
以下指令確保在執行等級   2,   3  ,  4,  5   下會叫出數據庫∶    
   
   
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc2.d/S99oracle  
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc3.d/S99oracle  
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc4.d/S99oracle  
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc5.d/S99oracle  
   
   
要在重新啓動時停止數據庫,我們需要以下連結∶    
   
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc0.d/K01oracle                 # 停止  
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc1.d/K01oracle                 # 停止 
$   ln   -s   ../init.d/oracle   /etc/rc.d/rc6.d/K01oracle                 # 重新啓動

========================
把oracle service添加到服務裏
# chkconfig –add /etc/rc.d/init.d/oracle

查看自動啓動設置是否成功:
# chkconfig –list oracle
oracle     0:關閉     1:關閉     2:關閉     3:開啓     4:開啓     5:開啓     6:關閉
*從上面可以看出level爲345的都已經開啓了,配置成功!
===============================

linux下系統開機oracle自啓動(方法二)
以root身份登錄:
$su - root
1、linux下oracle自帶的dbstart和dbshut沒反應:   修改Oracle系統配置文件/etc/oratab文件: #vi /etc/oratab
  /etc/oratab 格式爲: SID:ORACLE_HOME:AUTO
  把AUTO域設置爲Y(大寫),我的爲:
  oradb:/opt/u01/app/oracle/product/9.2.0.4:Y

   只有這樣,oracle 自帶的dbstart和dbshut才能夠發揮作用。
2、修改/etc/rc.d/rc.local配置文件
   在/etc/rc.d/rc.local中加入如下內容: #vi /etc/rc.d/rc.local
   su - oracle -c "/u01/app/oracle/product/9.2.0.4/bin/lsnrctl start"
   su - oracle -c "/u01/app/oracle/product/9.2.0.4/bin/dbstart start"
3、重新啓動
  #reboot
4、連接測試(以oracle身份登錄)
  $sqlplus "
[email=sys/oracle@oradb]sys/oracle@oradb[/email]
as sysdba"
  ...
  sql>
5、說明自啓動成功了



轉載自:http://blog.csdn.net/cheng168520/article/details/4312823

發佈了36 篇原創文章 · 獲贊 6 · 訪問量 16萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章