教你怎樣用Oracle方便地查看報警日志錯誤
在網(wǎng)上查了幾天的資料,嘗試綜合清除告警日志內(nèi)容及建外部表的方式來解決這一問題。
一:備份并清除告警日志內(nèi)容
將每天的告警日志備份好,然后進行清除。
1:備份報警日志
在$ORACLE_HOME/SID/bdump/ 目錄下,
按日期備份alert_ORACLE_你的實例名.LOG這個文件,如:alert_ORACLE_orcl_201408111639_bak.LOG。
2:清除日志內(nèi)容
打開報警日志文件,用true > 文件名 可清除掉里面的內(nèi)容
具體示例:
假如,我現(xiàn)在第一次進行該設(shè)置,我先把現(xiàn)有的告警日志進行備份,如:
--備份文件名稱:今天16點24分前的告警日志信息
[oracle@rac2 bdump]$ cp alert_orcl2.log alert_orcl2_before_201408111624_bak.log
-清空報警日志
[oracle@rac2 bdump]$ true > alert_orcl2.log
現(xiàn)在告警日志是空的。
切換下歸檔日志,檢查報警日志里是否出現(xiàn)了新內(nèi)容:
SQL> alter system switch logfile; System altered.
則現(xiàn)在alert_orcl2.log記錄的是2014年8月11日16點24分后至你下次對報警日志進行備份,截取前的信息。
二:建外部表查看報警日志錯誤
如果已建立了一個用戶,并賦相應(yīng)的權(quán)限,所以直接建立目錄對象并建立外部表就可以了。
1.建立目錄對象
SQL> conn test / 123
Connected. SQL> create directory bdump as '/oracle/u01/app/oracle/admin/db2/bdump'; Directory created.
2.建立外部表
SQL> create table alert_log( text varchar2(400) )organization external (type oracle_loader default directory bdump access parameters (records delimited by newline )location('alert_db2.log') );
3.測試首先查看能否查到alert_db2.log的內(nèi)容
SQL> select * from alert_log where rownum < 10; TEXT -------------------------------------------------------------------------------- Thu Jun 11 00:51:46 2009 Starting ORACLE instance (normal) Cannot determine all dependent dynamic libraries for /proc/self/exe Unable to find dynamic library libocr10.so in search paths RPATH = /ade/aime1_build2101/oracle/has/lib/:/ade/aime1_build2101/oracle/lib/:/a de/aime1_build2101/oracle/has/lib/: LD_LIBRARY_PATH is not set! The default library directories are /lib and /usr/lib Unable to find dynamic library libocrb10.so in search paths Unable to find dynamic library libocrutl10.so in search paths 9 rows selected.
測試成功
然后我們測試查報警信息'ORA-%'
SQL> select * from alert_log where text like 'ORA-%'; TEXT -------------------------------------------------------------------------------- ORA-00202: control file: '/oracle/u01/app/oracle/product/10.2.0/db2/dbs/cntrldb2 .dbf' ORA-27037: unable to obtain file status ORA-205 signalled during: ALTER DATABASE MOUNT... ORA-00301: error in adding log file '/home/oracle/oracle/oradata/testdb/redo01.l og' - file cannot be created ORA-27040: file create error ORA-1501 signalled during: CREATE DATABASE db2 ORA-00200: control file could not be created TEXT -------------------------------------------------------------------------------- ORA-00202: control file: '/oracle/u01/app/oracle/product/10.2.0/db2/dbs/cntrldb2 .dbf' ORA-27038: created file already exists ORA-1501 signalled during: CREATE DATABASE db2 ORA-00200: control file could not be created ORA-00202: control file: '/oracle/u01/app/oracle/product/10.2.0/db2/dbs/cntrldb2 .dbf' ORA-27038: created file already exists ORA-1501 signalled during: CREATE DATABASE db2
--假如,你的報警日志文件只包含今天的信息(可以通過備份并清除告警日志內(nèi)容實現(xiàn)),則通過外部表可以查到當天產(chǎn)生了哪些錯誤。
- plsql連接oracle數(shù)據(jù)庫報ora 12154錯誤解決方法
- oracle錯誤代碼大全(超詳細)
- win7安裝oracle10g 提示程序異常終止 發(fā)生未知錯誤
- 在oracle 數(shù)據(jù)庫中查看一個sql語句的執(zhí)行時間和SP2-0027錯誤
- oracle 10g OEM常規(guī)錯誤(Unknown host specified)解決
- oracle 11g導(dǎo)出數(shù)據(jù)時報ORA 1455錯誤的處理方法
- Oracle AS關(guān)鍵字 提示錯誤
- Oracle數(shù)據(jù)庫TNS常見錯誤的解決方法匯總
- CentOS6.2上安裝Oracle10g報ins_emdb.mk錯誤處理方法
- oracle 11g配置 解決啟動連接數(shù)據(jù)庫出現(xiàn)的ora錯誤
相關(guān)文章
Oracle平臺應(yīng)用數(shù)據(jù)庫系統(tǒng)的設(shè)計與開發(fā)
Oracle平臺應(yīng)用數(shù)據(jù)庫系統(tǒng)的設(shè)計與開發(fā)...2007-03-03Oracle 數(shù)據(jù)庫導(dǎo)出(exp)導(dǎo)入(imp)說明
exp 將數(shù)據(jù)庫內(nèi)的各對象以二進制方式下載成dmp文件,方便數(shù)據(jù)遷移。2009-02-02