1. 程式人生 > >一個ORA-16014和ORA-00312錯誤的解決

一個ORA-16014和ORA-00312錯誤的解決

為了測試向一個表中插入1000萬條資料,因為有大量的日誌產生,所以事先手工(非RMAN)刪除了歸檔日誌,以免因空間不足
而失敗。在插入資料過程中,資料庫還是down掉了。shutdown後發現數據庫無法開啟。


SQL> alter database open;
ERROR at line 1:
ORA-16014: log 1 sequence# 92 not archived, no available destinations
ORA-00312: online log 1 thread 1: 'C:/ORACLE/PRODUCT/10.2.0/ORADATA/ORCL/REDO01.LOG'

SQL> select * from v$log
;

    GROUP#    THREAD#  SEQUENCE#      BYTES    MEMBERS ARC STATUS           FIRST_CHANGE# FIRST_TIME
---------- ---------- ---------- ---------- ---------- --- ---------------- ------------- ----------
         1          1         93   52428800          1 NO  INACTIVE               4345718 04-FEB-09
         3          1         94   52428800          1 NO  INACTIVE               4347356 04-FEB-09
         2          1         95   52428800          1 NO  CURRENT                4368182 04-FEB-09

從以上資訊猜測,由於GROUP1無法歸檔引起,檢查歸檔空間
 

SQL> show parameter db_recovery_file_dest_size

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest_size           big integer 3G

通過檢查實際的歸檔資料夾後發現,實際使用的歸檔空間的遠遠小於3G,猜測可能由於手工刪除歸檔日誌所致。
採用以下方法解決:


當手工刪除了歸檔日誌以後,Rman備份會檢測到日誌缺失,從而無法進一步繼續執行。
所以此時需要手工執行crosscheck過程,之後Rman備份可以恢復正常。
1.Crosscheck日誌

$ rman target /
Recovery Manager: Release 9.2.0.4.0 - 64bit Production
Copyright (c) 1995, 2002, Oracle Corporation. All rights reserved.
connected to target database: AVATAR2 (DBID=2480694409)

RMAN> crosscheck archivelog all;

using target database controlfile instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: sid=25 devtype=DISK
validation failed for archived log
.........................................

RMAN>


2.使用delete expired archivelog all 命令刪除所有過期歸檔日誌:


RMAN> delete expired archivelog all;


RCL/ARCHIVELOG/2009_02_04/O1_MF_1_86_4RL2RJWB_.ARC
81      1    87      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_87_4RL2RYGN_.ARC
82      1    88      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_88_4RL2SGFO_.ARC
83      1    89      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_89_4RL2SY0H_.ARC
84      1    90      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_90_4RL2TOB8_.ARC
85      1    91      X 04-2月 -09 C:/ORACLE/PRODUCT/10.2.0/FLASH_RECOVERY_AREA/O
RCL/ARCHIVELOG/2009_02_04/O1_MF_1_91_4RL2VHC7_.ARC

SQL> alter database open;
 

Database altered.