shutdown immediate 持久無法關閉數據庫之解決方案


問題引出:測試環境,進行oralce的shutdown immediate,等待時間很長,長的無法等待

ORACLE shutdown 過程:

1、shutdown normal(正常關閉方式):阻止任何用戶建立新的連接;等待當前所有正在連接的用戶主動斷開連接;當所有的用戶都斷開連接后,將立即關閉數據庫

2、shutdown transactional(實務關閉方式):阻止用戶連接新的連接和開始新事務;等待所有活動事務提交后,再斷開用戶連接;當所有的活動實務提交完畢、所有的用戶都斷開連接后,將關閉數據庫

3、shutdown immediate(立即關閉方式):阻止用戶連接新連接和開始新事務;將未提交的活動事務回退;關閉數據庫

4、shutdown abort(終止關閉方式):阻止用戶建立新連接和開始新事務;取消未提交的活動事務,而不是回退;立即終止正在執行的任何SQL語句;立即關閉數據庫

無疑,shutdown abort是最開速關閉數據庫的方式,但是很可能會使數據庫處於不一致狀態,嚴重可能損壞數據庫,導致數據庫起不來,特別是生產環境。雖然現在是測試環境,但是也不建議這樣做。推薦使用shutdown immediate方式關閉數據庫。

快速關閉數據庫的因素:

1、連接的客戶端進程數量

2、未提交的事務占用的UNDO BLOCK數量

3、長時間運行的會話

4、SMON進程清理臨時段的速度

2、查看預警日志文件(alert_sid.log)的位置 

SQL> show parameter dump 
NAME TYPE VALUE 
------------------------------------ ----------- ------------------------------ 
background_core_dump string partial 
background_dump_dest string /u01/oracle/admin/bdump 
core_dump_dest string /u01/oracle/admin/cdump 
max_dump_file_size string 10240 
shadow_core_dump string partial 
user_dump_dest string /u01/oracle/admin/udump 

查看alert日志如下: /u01/oracle/admin/bdump/alert_biusdb.log  以下信息是樣例

Shutting down instance (immediate)
Sat Aug 24 15:25:40 2013
Shutting down instance: further logons disabled
License high water mark = 683
Sat Aug 24 15:30:39 2013
Active call for process 26760 user 'orarep' program'oracle@pmsdb2'
Active call for process 20349 user 'orarep' program'oracle@pmsdb2'
Active call for process 1813 user 'orarep' program'oracle@pmsdb2'
Active call for process 10694 user 'orarep' program'oracle@pmsdb2'
Active call for process 26394 user 'orarep' program'oracle@pmsdb2'
System State dumped to trace file /oraprep/oracle/admin/repdb/udump/repdb_ora_16122.trc
Sat Aug 24 15:31:02 2013
SHUTDOWN: waiting for active calls to complete.
Sat Aug 24 15:31:02 2013
Instance shutdown cancelled
Sat Aug 24 15:35:56 EAT 2013
Shutting down instance (immediate)
Sat Aug 24 15:35:56 EAT 2013
Shutting down instance: further logons disabled
License high water mark = 683

隨機,手動kill掉這些數據庫連接進程:

eg:

orarep@pmsdb2[/oraprep/oracle/admin/repdb/bdump]$kill -9 10694
orarep@pmsdb2[/oraprep/oracle/admin/repdb/bdump]$kill -9 23362
orarep@pmsdb2[/oraprep/oracle/admin/repdb/bdump]$kill -9 9944

另外如果進程之多可以使用:

ps aux |grep "LOCAL=NO" |awk '{printf "%s\n", $2}' |xargs kill -9

ps -ef|grep $ORACLE_SID|grep -v ora_|grep LOCAL=NO|awk '{print $2}'|xargs kill

命令

隨機再次關閉數據庫:

SQL> shutdown immediate

Database closed.

Database dismounted.

總結:

這是由於進程lock資源導致 的問題,因此需要先釋放資源,完成數據庫的關閉。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM