DATAGUARD中手工處理日誌GAP
從9i以後,一般都不需要手工處理確實的日誌,FAL自動會幫我們處理這些問題。
但是,並非我們就完全不用手工處理了,比如,你的磁碟空間爆滿,歸檔日誌在傳到備庫前被轉移到其他地方,這種情況下FAL是不能解決問題的,需要手工處理一下。
下面就簡單說說手工處理日誌GAP的步驟:
1、在備庫檢查是否有日誌缺失
SQL> select * from V$ARCHIVE_GAP;
THREAD# LOW_SEQUENCE# HIGH_SEQUENCE#
---------- ------------- --------------
1 99 109
從上面的資訊可以看出,備庫中缺失了99到109的日誌。
2、在主庫中查詢缺失的日誌的所在路徑和名稱
SQL> SELECT NAME FROM V$ARCHIVED_LOG WHERE THREAD#=1 AND DEST_ID=1 AND SEQUENCE# BETWEEN 99 AND 109;
NAME
--------------------------------------------------------------------------------
/u01/archivelog/1_99_626106231.arc
/u01/archivelog/1_100_626106231.arc
/u01/archivelog/1_101_626106231.arc
/u01/archivelog/1_102_626106231.arc
/u01/archivelog/1_103_626106231.arc
/u01/archivelog/1_104_626106231.arc
/u01/archivelog/1_105_626106231.arc
/u01/archivelog/1_106_626106231.arc
/u01/archivelog/1_107_626106231.arc
/u01/archivelog/1_108_626106231.arc
/u01/archivelog/1_109_626106231.arc
如果把日誌移動到其他路徑,則把日誌所在路徑換成當前實際所在路徑。
3、把日誌複製到備庫上
sftp> get 1_99_626106231.arc
Fetching /u01/archivelog/archive/1_99_626106231.arc to 1_99_626106231.arc
/u01/archivelog/archive/1_99_626106231.arc 100% 17KB 17.0KB/s 00:00
sftp> mget 1_10*
Fetching /u01/archivelog/archive/1_100_626106231.arc to 1_100_626106231.arc
/u01/archivelog/archive/1_100_626106231.arc 100% 4962KB 2.4MB/s 00:02
......
Fetching /u01/archivelog/archive/1_10_626106231.dbf to 1_10_626106231.dbf
/u01/archivelog/archive/1_10_626106231.dbf 100% 40KB 40.0KB/s 00:00
4、在備庫上手工註冊上一步中從主庫複製來的日誌
SQL> ALTER DATABASE REGISTER LOGFILE '/u01/archivelog/1_99_626106231.arc';
Database altered.
......
SQL> ALTER DATABASE REGISTER LOGFILE '/u01/archivelog/1_109_626106231.arc';
Database altered.
5、稍等片刻,觀察備庫的alert日誌資訊
Sun Aug 12 20:38:47 2007
Media Recovery Log /u01/archivelog/1_99_626106231.arc
Media Recovery Log /u01/archivelog/1_100_626106231.arc
Media Recovery Log /u01/archivelog/1_101_626106231.arc
Media Recovery Log /u01/archivelog/1_102_626106231.arc
......
從以上資訊,可以看出之前註冊的日誌已經被正常應用。
6、檢查備庫是否還有日誌GAP
SQL> select * from V$ARCHIVE_GAP;
no rows selected
如果有行返回,則重複2-5步,直到查詢結果是"no rows selected"。
如果日誌只是臨時移動到其他地方,過後會再移回原路徑,則不用這麼大費周折手工去手工處理了,把日誌拷回原處後FAL會自動處理GAP。
但是,並非我們就完全不用手工處理了,比如,你的磁碟空間爆滿,歸檔日誌在傳到備庫前被轉移到其他地方,這種情況下FAL是不能解決問題的,需要手工處理一下。
下面就簡單說說手工處理日誌GAP的步驟:
1、在備庫檢查是否有日誌缺失
SQL> select * from V$ARCHIVE_GAP;
THREAD# LOW_SEQUENCE# HIGH_SEQUENCE#
---------- ------------- --------------
1 99 109
從上面的資訊可以看出,備庫中缺失了99到109的日誌。
2、在主庫中查詢缺失的日誌的所在路徑和名稱
SQL> SELECT NAME FROM V$ARCHIVED_LOG WHERE THREAD#=1 AND DEST_ID=1 AND SEQUENCE# BETWEEN 99 AND 109;
NAME
--------------------------------------------------------------------------------
/u01/archivelog/1_99_626106231.arc
/u01/archivelog/1_100_626106231.arc
/u01/archivelog/1_101_626106231.arc
/u01/archivelog/1_102_626106231.arc
/u01/archivelog/1_103_626106231.arc
/u01/archivelog/1_104_626106231.arc
/u01/archivelog/1_105_626106231.arc
/u01/archivelog/1_106_626106231.arc
/u01/archivelog/1_107_626106231.arc
/u01/archivelog/1_108_626106231.arc
/u01/archivelog/1_109_626106231.arc
如果把日誌移動到其他路徑,則把日誌所在路徑換成當前實際所在路徑。
3、把日誌複製到備庫上
sftp> get 1_99_626106231.arc
Fetching /u01/archivelog/archive/1_99_626106231.arc to 1_99_626106231.arc
/u01/archivelog/archive/1_99_626106231.arc 100% 17KB 17.0KB/s 00:00
sftp> mget 1_10*
Fetching /u01/archivelog/archive/1_100_626106231.arc to 1_100_626106231.arc
/u01/archivelog/archive/1_100_626106231.arc 100% 4962KB 2.4MB/s 00:02
......
Fetching /u01/archivelog/archive/1_10_626106231.dbf to 1_10_626106231.dbf
/u01/archivelog/archive/1_10_626106231.dbf 100% 40KB 40.0KB/s 00:00
4、在備庫上手工註冊上一步中從主庫複製來的日誌
SQL> ALTER DATABASE REGISTER LOGFILE '/u01/archivelog/1_99_626106231.arc';
Database altered.
......
SQL> ALTER DATABASE REGISTER LOGFILE '/u01/archivelog/1_109_626106231.arc';
Database altered.
5、稍等片刻,觀察備庫的alert日誌資訊
Sun Aug 12 20:38:47 2007
Media Recovery Log /u01/archivelog/1_99_626106231.arc
Media Recovery Log /u01/archivelog/1_100_626106231.arc
Media Recovery Log /u01/archivelog/1_101_626106231.arc
Media Recovery Log /u01/archivelog/1_102_626106231.arc
......
從以上資訊,可以看出之前註冊的日誌已經被正常應用。
6、檢查備庫是否還有日誌GAP
SQL> select * from V$ARCHIVE_GAP;
no rows selected
如果有行返回,則重複2-5步,直到查詢結果是"no rows selected"。
如果日誌只是臨時移動到其他地方,過後會再移回原路徑,則不用這麼大費周折手工去手工處理了,把日誌拷回原處後FAL會自動處理GAP。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/231499/viewspace-63845/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 在DATAGUARD中手工處理日誌GAP的方法
- ORACLE DATAGUARD中手工處理日誌v$archive_GAP的方法OracleHive
- 【DG】 DataGuard 中處理archive gap的方法Hive
- 【DATAGUARD】手工恢復備庫日誌中斷
- ORACLE 11G DATAGUARD 日誌中斷處理方案Oracle
- DATAGUARD手工註冊歸檔日誌(轉載)
- Oracle DataGuard歸檔日誌丟失處理方法Oracle
- [zt] 手工處理Standby 歸檔間隔(gap)的問題
- nginx日誌處理Nginx
- PHP日誌處理類PHP
- 使用RMAN增量備份處理Dataguard因歸檔丟失造成的gap
- orbeon form 的日誌處理ORBORM
- shell日誌顏色處理
- DataGuard日誌傳輸模式模式
- 手工建立多路重做日誌組
- 物理Data Guard中哪個程式處理Redo GAP
- node錯誤處理與日誌
- logstash kafka output 日誌處理Kafka
- oracle alert日誌亂碼處理Oracle
- strom打造日誌處理系統
- Db2 日誌處理二DB2
- apache日誌匯入oracle(日誌經過python處理)ApacheOraclePython
- oracle 中 alert 報警日誌過大的處理方法Oracle
- Redo Gap 處理與優化優化
- DG發現gap處理流程
- 【DataGuard】Oracle DataGuard 日誌傳輸狀態監控Oracle
- 如何在zuul上做日誌處理Zuul
- 搭建node服務(1):日誌處理
- 指令碼處理iOS的Crash日誌指令碼iOS
- logstash nginx error access 日誌處理NginxError
- 處理Apache日誌的Bash指令碼Apache指令碼
- 丟失重做日誌怎麼處理
- SQL Server日誌檔案總結及日誌滿的處理SQLServer
- ES & Filebeat 使用 Pipeline 處理日誌中的 @timestamp
- 一次dg 因密碼檔案與gap引起歸檔日誌無法應用的處理密碼
- DATAGUARD主庫重做日誌不能同步至備庫 alert日中報ORA-12170故障處理
- 【故障處理】手工刪除歸檔日誌導致RMAN備份時報ORA-19625錯誤
- Data guard archive GAP 故障處理案例Hive