Oracle hang 之sqlplus -prelim使用方法

531079521發表於2015-06-16
轉自:http://itspace.iteye.com/blog/626121
很多情況下,Oracle hang導致sqlplus無法連線,從而無法獲得Oracle系統和程式狀態,使得定位問題缺少強有力的依據。所幸的是Oracle 10g推出了sqlplus -prelim選項,在Oracle掛起時依然能使用sqlplus,從而能獲得資料庫狀態。
使用方法如下
引用
$ sqlplus -prelim "/as sysdba"

SQL*Plus: Release 10.2.0.4.0 - Production on Sun Mar 28 06:40:21 2010

Copyright (c) 1982, 2007, Oracle.  All Rights Reserved.

在prelim模式下,不可以查詢資料字典,但可以關閉資料庫
引用
SQL> select status from v$instance;
select status from v$instance
*
ERROR at line 1:
ORA-01012: not logged on

引用
SQL> shutdown abort
ORACLE instance shut down.

但可以使用oradebug,但對於系統診斷,已經足夠了
dump系統狀態
引用
SQL> oradebug setmypid                                            
Statement processed.
SQL> oradebug unlimit
Statement processed.
SQL> oradebug dump systemstate 266
Statement processed.

或者dump hanganalyze
引用
SQL> oradebug  hanganalyze 3
Hang Analysis in /oracle/app/oracle/admin/ora10g/udump/ora10g_ora_52642.trc

對於rac

引用
SQLPLUS> oradebug setmypid

SQLPLUS>oradebug setinst all

SQLPLUS>oradebug -g def hanganalyze 3


或者dump 程式狀態
引用
SQL> oradebug dump processstate 10
Statement processed.


進一步,如果有10g客戶端,資料庫是9i,依然可以用-prelim
引用
$ sqlplus -prelim /nolog

SQL*Plus: Release 10.2.0.4.0 - Production on Sun Mar 28 06:50:19 2010

Copyright (c) 1982, 2007, Oracle.  All Rights Reserved.

SQL> conn sys/oracle@ora9i as sysdba
Prelim connection established
SQL>  oradebug setmypid
Statement processed.
SQL> oradebug unlimit
Statement processed.
SQL>  oradebug dump systemstate 266
Statement processed.

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28841119/viewspace-1701561/,如需轉載,請註明出處,否則將追究法律責任。

相關文章