oracle 10g 报错:ORA-00257: archiver error. Connect internal only, until freed
今天在公司,突然同事告訴我數據庫無法登錄了,想想這段時間沒有動過庫,為什么無法登錄呢?一邊想是什么問題,一邊連接測試登錄。
首先報錯:ORA-00257: archiver error. Connect internal only, until freed.
趕緊上網一查:
這一段是從網上截過來的 從Oracle9i開始,借助于undo日志文件提供了閃回查詢的功能,由于功能也有一定的局限性,也就是說依賴于UNDO日志的事務不能被覆蓋,所以在oracle10g開始又采用了一種新的FlashBack日志來實現這個功能,而且更為強大,可以將數據庫退回到過去的某個時間點去。這個文件默認最大為2g 。但是在一段時間過后,很快就達到了2G,這個時候就會出現ORA--00257 錯誤了。
有兩種解決方法:
第一種 就是關閉閃回日志的功能,這種對于開發環境中不失為一種好方法,因為開發環境中,并不追求數據的可安全性什么的。通過如下語句可以改:
alter database flashback off
第二種 就是增大閃回日志文件的最大值,如下:
alter system set DB_RECOVERY_FILE_DEST_SIZE=10g
這個時候,你可以去查看V$flash_recovery_area_usage 視圖中的使用率情況,這個時候發現使用率(PERCENT_SPACE_USED列的值)已經大大降低了。再通過如下語句去查看系統日志文件情況。
select * from V$log 會發現現在redo日志文件也可以正常寫入了,至此問題解決。
我的解決過程:
首先我用sys(sysdba)帳戶登錄,還好可以登錄,如果這也無法登錄,那我就更傷心了。然后用第一種方法,過了幾分鐘,還在處理階段一直顯示無法完成,就放棄了。
馬上使用第二種方法,修改日志文件大小為10g,然后查詢,發現使用率確實比較小,再用普通用戶登錄,OK,可以登錄了,至此問題解決了。
?
據數據庫目前可用存儲空間情況、FLASH_RECOVERY_AREA空間為2GB的實際情況,把FLASH_RECOVERY_AREA的空間修改為20GB()。
SQL> alter system set DB_RECOVERY_FILE_DEST_SIZE=20g;
系統已更改。
(其實問題的本質是歸檔日志的使用已經達到了spfile等啟動參數文件中指定的最大值。oracle 10g中歸檔日志默認的存放地是閃回目錄,即%ORACLE_BASE%/flash_recovery_area的相應實例名下面,這個位置的大小在參數文件中有個限制,解決空間不足的問題可以通過兩種方式來實現,一個修改這個大小限制,還有一個就是修改歸檔日志存放位置。)
如果不要這些archivelog的話,可以刪除一些
rman>DELETE NOPROMPT ARCHIVELOG UNTIL TIME 'SYSDATE-3'; 直接運行這條 這樣會只保留三天的歸檔
sql> select * from v$flash_recovery_area_usage;
FILE_TYPE??????????????? PERCENT_SPACE_USED??? PERCENT_SPACE_RECLAIMABLE?? NUMBER_OF_FILES
------------------------------- -------------------------------------?? ?? -----------------------------------------------------?? -------------------------------
CONTROLFILE??????????????????? 0?????????????????????????????????????????????????????????? 0???????????????????????????????????? ?? 0
ONLINELOG???????????????????? ?? 0?????????????????????????????????????????????????? ?????? 0??????????????????????????????????? ??? 0
ARCHIVELOG???????????????? 6.11?????????????????????????????????????????????????????? ?? 0??????????????????????????????????? ??? 3
BACKUPPIECE?????????????????? 0?????????????????????????????????????????????????????? ?? 0??????????????????????????????????? ??? 0
IMAGECOPY???????????????????? 0???????????????????????????????????????????????????? ??? 0?????????????????????????????????? ????? 0
FLASHBACKLOG??????????????? 0??????????????????????????????????????????????????????? 0?????????????????????????????????? ????? 0
還可參考:http://www.eygle.com/archives/2004/12/rman_crosscheck.html
?
總結
以上是生活随笔為你收集整理的oracle 10g 报错:ORA-00257: archiver error. Connect internal only, until freed的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微信小程序时间戳的转换及调用
- 下一篇: 算法导论第三版第二章答案