Redo Log File(inactive、active)損壞,處理恢復對策
redolog的生命週期中共有四種狀態:
current -> 正在使用的
active -> 非正在使用的,對應的Dirty Block還沒有完全寫入到資料檔案中
inactive -> 非正在使用的,可以覆蓋的,Dirty Block已經完全寫入。
unused -> 沒有使用過的
-- 檢視redolog狀態
SQL> select group#,status from v$log;
模擬三種狀態下redolog丟失,處理方案:
一、inactive 情況 (Inactive表示Dirty Block已經完全寫入。)
-- 檢視redolog狀態
SQL> select group#,status from v$log;
GROUP# STATUS
---------- ----------------
1 INACTIVE
2 CURRENT
3 UNUSED
SQL>
col member for a45;
select group#,status,type,member from v$logfile;
GROUP# STATUS TYPE MEMBER
---------- ------- ------- ---------------------------------------------
3 ONLINE /home/oracle/app/oradata/orcl/redo03.log
2 ONLINE /home/oracle/app/oradata/orcl/redo02.log
1 ONLINE /home/oracle/app/oradata/orcl/redo01.log
--模擬 inactive 狀態丟失
[oracle@11g orcl]$ rm -rf /home/oracle/app/oradata/orcl/redo01.log
-- inactive 丟失後的資料庫症狀
[oracle@11g trace]$ tail -f alert_orcl.log
Errors in file /home/oracle/app/diag/rdbms/orcl/orcl/trace/orcl_m000_25727.trc:
ORA-00313: open failed for members of log group 1 of thread 1
ORA-00312: online log 1 thread 1: '/home/oracle/app/oradata/orcl/redo01.log'
ORA-27037: unable to obtain file status
Linux-x86_64 Error: 2: No such file or directory
Additional information: 3
SQL> alter system switch logfile; (多切幾次日誌後,會話hang住)
SQL> conn andy/andy (使用者登入不進去)
ERROR:
ORA-00257: archiver error. Connect internal only, until freed.
Warning: You are no longer connected to ORACLE.
--處理流程
SQL> alter database clear logfile group 1 ;
alter database clear logfile group 1
*
ERROR at line 1:
ORA-00350: log 1 of instance orcl (thread 1) needs to be archived
ORA-00312: online log 1 thread 1: '/home/oracle/app/oradata/orcl/redo01.log'
SQL> select group#,sequence#,archived,status from v$log;
GROUP# SEQUENCE# ARC STATUS
---------- ---------- --- ----------------
1 4 NO INACTIVE
2 5 NO INACTIVE
3 6 NO CURRENT
SQL> alter database clear unarchived logfile group 1;
Database altered.
-- 檢查redo自否正常建立
[oracle@11g ~]$ cd /home/oracle/app/oradata/orcl/
[oracle@11g orcl]$ ll redo*
-rw-r-----. 1 oracle oinstall 52429312 Mar 25 13:44 redo01.log
-rw-r-----. 1 oracle oinstall 52429312 Mar 25 13:19 redo02.log
-rw-r-----. 1 oracle oinstall 52429312 Mar 25 13:36 redo03.log
SQL> alter system switch logfile;
System altered.
SQL> /
SQL> /
SQL> /
SQL> select group#,sequence#,archived,status from v$log
GROUP# SEQUENCE# ARC STATUS
---------- ---------- --- ----------------
1 10 YES INACTIVE
2 11 YES INACTIVE
3 12 NO CURRENT
資料庫恢復正常,OK。
————————————————————————————————————————————————————————
二、 active 情況 (Active是說日誌組已經不是當前日誌組,但是Redo Log Entry對應的Dirty Block還沒有完全寫入到資料檔案中。)
--切換日誌直至 redolog 的 status 出現 ACTIVE
SQL> alter system switch logfile;
System altered.
SQL> alter system switch logfile;
System altered.
SQL> select group#,sequence#,archived,status from v$log;
GROUP# SEQUENCE# ARC STATUS
---------- ---------- --- ----------------
1 13 YES ACTIVE
2 14 NO CURRENT
3 12 YES ACTIVE
--模擬 ACTIVE 狀態的 redolog 丟失
[oracle@11g orcl]$ rm -rf redo01.log
--資料庫狀態
[oracle@11g trace]$ tail -f alert_orcl.log
Errors in file /home/oracle/app/diag/rdbms/orcl/orcl/trace/orcl_arc2_23552.trc:
ORA-00313: open failed for members of log group 1 of thread 1
ORA-00312: online log 1 thread 1: '/home/oracle/app/oradata/orcl/redo01.log'
ORA-27037: unable to obtain file status
Linux-x86_64 Error: 2: No such file or directory
Additional information: 3
Master background archival failure: 313
SQL> alter system switch logfile; (多次切換redolog,發現多次以後會話 hang 住)
--處理過程
SQL> select group#,sequence#,archived,status from v$log;
GROUP# SEQUENCE# ARC STATUS
---------- ---------- --- ----------------
1 16 NO INACTIVE
2 17 NO INACTIVE
3 18 NO CURRENT
SQL> alter database clear unarchived logfile group 1;
--檢查redolog是否正常生成
[oracle@11g orcl]$ ll redo*
-rw-r-----. 1 oracle oinstall 52429312 Mar 25 14:31 redo01.log
-rw-r-----. 1 oracle oinstall 52429312 Mar 25 14:32 redo02.log
-rw-r-----. 1 oracle oinstall 52429312 Mar 25 14:31 redo03.log
--多次切換日誌,看資料庫是否正常
SQL> alter system switch logfile;
System altered.
SQL> /
System altered.
SQL> /
System altered.
SQL> /
System altered.
OK,一切正常。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31383567/viewspace-2138062/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle redo各種狀態(inactive、active、current)損壞的處理方式Oracle Redo
- Oracle-真實環境的丟失current redo log file的故障恢復Oracle
- redo log file 最佳化
- redo損壞修復啟動資料庫辦法資料庫
- How to Dump Redo Log File Information --metalinkORM
- 基於Redo Log和Undo Log的MySQL崩潰恢復流程MySql
- 控制檔案損壞處理
- Oracle asm磁碟損壞異常恢復OracleASM
- u盤檔案損壞怎麼恢復資料 u盤恢復損壞資料的有效方法
- log file sync等待事件處理思路事件
- 資料底層損壞的恢復方法—拼碎片恢復資料
- u盤檔案損壞怎麼恢復資料 u盤損壞無法讀取怎麼恢復資料
- windows10應用商店損壞怎麼修復_win10應用商店損壞處理方法WindowsWin10
- MySQL資料庫INNODB表損壞修復處理過程分享MySql資料庫
- 隨身碟顆粒損壞資料恢復資料恢復
- RAC磁碟頭損壞問題處理
- Oracle RAC+DG 調整redo/standby log fileOracle
- 深入解析:段頭塊損壞bbed異常恢復
- 資料恢復工具Recoverit使用教程:如何修復損壞的影片資料恢復
- WPS文件損壞如何修復?WPS文件損壞的修復方法
- 電腦進水導致硬碟損壞資料恢復硬碟資料恢復
- 更改online redo log file 提示 ORA-01511 ORA-01141
- Oracle Redo丟失恢復方案Oracle
- 處理恢復資料方法
- win10ie核心損壞怎麼修復_win10電腦ie顯示核心丟失或損壞處理方法Win10
- Oracle資料庫不同損壞級別的恢復詳解Oracle資料庫
- Win10系統損壞的cbs.log檔案如何修復Win10
- undo log和redo log
- 資料庫資料恢復—NTFS分割槽損壞如何恢復SqlServer資料庫資料資料庫資料恢復SQLServer
- 【資料庫資料恢復】MongoDB資料庫檔案損壞的資料恢復案例資料庫資料恢復MongoDB
- 【儲存資料恢復】IBM儲存檔案NTFS系統損壞的資料恢復案例資料恢復IBM
- 伺服器硬碟磁頭損壞,碟片劃傷資料恢復伺服器硬碟資料恢復
- 伺服器系統癱瘓系統損壞資料恢復伺服器資料恢復
- PostgreSQL DBA(30) - Backup&Recovery#3(資料檔案損壞恢復)SQL
- Oracle Database 12c RAC損壞ocr和votedisk恢復實驗OracleDatabase
- ibdata1檔案損壞時恢復InnoDB單表測試
- linux下修復磁碟損壞Linux
- 【伺服器資料恢復】IBM儲存伺服器硬碟壞道離線、oracle資料庫損壞的資料恢復伺服器資料恢復IBM硬碟Oracle資料庫
- 資料庫資料恢復-SQL SERVER資料庫MDF (NDF)或LDF損壞如何恢復資料?資料庫資料恢復SQLServer