(轉)ORA-00257解決
原:http://blog.chinaunix.net/u/26381/showart_373304.html
從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日誌檔案也可以正常寫入,至此問題解決。
-------------------------------------------------------------------
講解Oracle資料庫ORA-00257故障的解決過程
原文:http://developer.weaseek.com/2008/0715/47199469_1.shtml 2008-07-15 15:39:13 來源:賽迪網
在實際專案中遇到了ORA-00257錯誤(空間不足錯誤),透過查詢資料,絕大部分說這是由於歸檔日誌太多,佔用了全部的硬碟剩餘空間導致的,透過簡單刪除日誌或加大儲存空間就能夠解決。但是我在Oracle 10g上發現,儲存空間還有很大,卻也報這個錯誤。原來是Oracle 10g中新的特性,對Flash Recovery的管理導致的。
Oracle資料庫是目前業界最常用的大型資料庫系統,我在實際專案中遇到了ORA-00257錯誤(空間不足錯誤),透過查詢資料,絕大部分說這是由於歸檔日誌太多,佔用了全部的硬碟剩餘空間導致的,透過簡單刪除日誌或加大儲存空間就能夠解決。但是我在Oracle 10g上發現,儲存空間還有很大,卻也報這個錯誤。原來是Oracle 10g中新的特性,對Flash Recovery的管理導致的。
1、軟硬體環境
伺服器HP Proliant DL580G4(Intel Xeon 3.16GHz/4GB/ 72.8*4/RAID4)
作業系統Red Flag DC Server release 5.0 (Trinity) for x86-64 Linux
資料庫Oracle 10.2.0.1.0
2、問題現象
資料庫系統已經試執行了半個多月,在7月24日晚上連線資料庫後做資料更新時出現ORA-00257錯誤,如下圖。
提示歸檔錯誤,透過查詢ORACLE錯誤程式碼,解釋為硬碟空間不足,需要刪除歸檔日誌增加空間,但是伺服器可用空間200GB,目前只用了10GB左右,這是為什麼呢?
3、診斷過程:
(1)檢視ORACLE資料庫歸檔日誌情況
[root@hrmsdb /]# cd /oracle/flash_recovery_area/HKCHR/archivelog
[root@hrmsdb archivelog]# ls
2006_07_04 2006_07_13 2006_07_17 2006_07_20 2006_07_23
2006_07_11 2006_07_14 2006_07_18 2006_07_21 2006_07_24
2006_07_12 2006_07_15 2006_07_19 2006_07_22 2006_07_25
[root@hrmsdb archivelog]# cd 2006_07_25
[root@hrmsdb 2006_07_25]# ls
[root@hrmsdb 2006_07_25]# cd ../2006_07_24
[root@hrmsdb 2006_07_24]# ls
o1_mf_1_92_2d933vgb_.arc o1_mf_1_96_2d954ns7_.arc o1_mf_1_98_2d969d5h_.arc
o1_mf_1_95_2d9537cs_.arc o1_mf_1_97_2d956km0_.arc
說明在出現問題之前資料庫歸檔處理一直是正常的。
(2)檢視資料庫REDOLOG情況
[oracle@hrmsdb ~]$ sqlplus /nolog
SQL*Plus: Release 10.2.0.1.0 - Production on 星期二 7月 25 10:44:18 2006
Copyright (c) 1982, 2005, Oracle. All rights reserved.
SQL> connect / as sysdba
已連線。
SQL> select * from v$log;
GROUP# THREAD# SEQUENCE# BYTES MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIME
---------- ---------- ---------- ---------- ----------
1 1 101 52428800 1 NO CURRENT 3621973 24-7月 -06
2 1 99 52428800 1 NO INACTIVE 3600145 24-7月 -06
3 1 100 52428800 1 NO INACTIVE 3611932 24-7月 -06
發現ARC狀態為NO,表示系統沒法自動做歸檔。
(3)手工切換日誌
SQL> alter system switch logfile;
alter system switch logfile
*
第1行出現錯誤:
ORA-01013: 使用者請求取消當前的操作
在等待長時間沒反應後,中斷操作,手工切換日誌沒有成功。
(4)檢視Oracle資料庫後臺歸檔服務程式
[oracle@hrmsdb ~]$ ps -ef|grep oracle
oracle 4601 1 0 Jul11 ? 00:00:04 /oracle/product/10.2.0/db_1/bin/
tnslsnr LISTENER -inherit
oracle 5025 1 0 Jul11 ? 00:00:00 /usr/bin/ssh-agent -s
oracle 20923 1 0 Jul24 ? 00:00:01 ora_pmon_hkchr
oracle 20925 1 0 Jul24 ? 00:00:00 ora_psp0_hkchr
oracle 20927 1 0 Jul24 ? 00:00:00 ora_mman_hkchr
oracle 20929 1 0 Jul24 ? 00:00:01 ora_dbw0_hkchr
oracle 20931 1 0 Jul24 ? 00:01:07 ora_lgwr_hkchr
oracle 20933 1 0 Jul24 ? 00:00:05 ora_ckpt_hkchr
oracle 20935 1 0 Jul24 ? 00:00:01 ora_smon_hkchr
oracle 20937 1 0 Jul24 ? 00:00:00 ora_reco_hkchr
oracle 20939 1 0 Jul24 ? 00:00:00 ora_cjq0_hkchr
oracle 20941 1 0 Jul24 ? 00:00:01 ora_mmon_hkchr
oracle 20943 1 0 Jul24 ? 00:00:05 ora_mmnl_hkchr
oracle 20945 1 0 Jul24 ? 00:00:00 ora_d000_hkchr
oracle 20947 1 0 Jul24 ? 00:00:00 ora_s000_hkchr
oracle 20953 1 0 Jul24 ? 00:09:41 ora_arc0_hkchr
oracle 20955 1 1 Jul24 ? 00:10:29 ora_arc1_hkchr
oracle 20959 1 0 Jul24 ? 00:00:00 ora_qmnc_hkchr
oracle 20967 1 0 Jul24 ? 00:00:00 ora_q000_hkchr
oracle 20969 1 0 Jul24 ? 00:00:00 ora_q001_hkchr
oracle 21715 1 0 Jul24 ? 00:00:19 oraclehkchr (LOCAL=NO)
oracle 21765 1 0 Jul24 ? 00:00:00 ora_j000_hkchr
oracle 21816 1 0 Jul24 ? 00:00:00 ora_j001_hkchr
oracle 21832 1 0 Jul24 ? 00:00:00 ora_j002_hkchr
oracle 21839 1 0 Jul24 ? 00:00:00 ora_j003_hkchr
oracle 21859 1 0 Jul24 ? 00:00:00 ora_j004_hkchr
oracle 21861 1 0 Jul24 ? 00:00:00 ora_j005_hkchr
oracle 21886 1 0 Jul24 ? 00:00:00 ora_j006_hkchr
oracle 21888 1 0 Jul24 ? 00:00:00 ora_j007_hkchr
root 23187 23186 0 10:39 ? 00:00:00 login -- oracle
oracle 23188 23187 0 10:39 pts/0 00:00:00 -bash
oracle 23216 23188 0 10:39 pts/0 00:00:00 sqlplus
oracle 23217 23216 0 10:39 ? 00:00:00 oraclehkchr (DESCRIPTION=(LOCAL=
YES)(ADDRESS=(PROTOCOL=beq)))
root 23224 23223 0 10:40 ? 00:00:00 login -- oracle
oracle 23225 23224 0 10:40 pts/1 00:00:00 -bash
oracle 23310 23225 0 10:46 pts/1 00:00:00 ps -ef
oracle 23311 23225 0 10:46 pts/1 00:00:00 grep oracle
[oracle@hrmsdb ~]$
後臺程式都正常執行。
(5)檢視FLASH_RECOVERY_AREA空間使用情況
[root@hrmsdb /]# cd /oracle
[root@hrmsdb oracle]# ls
admin flash_recovery_area oraInventory product
[root@hrmsdb oracle]# du -a -k flash_recovery_area
4 flash_recovery_area/HKCHR/onlinelog
42456 flash_recovery_area/HKCHR/archivelog/2006_07_15/o1_mf_1_74_2cj1h1jz_.arc
……………….
42448 flash_recovery_area/HKCHR/archivelog/2006_07_14/o1_mf_1_68_2cfzwwvt_.arc
512560 flash_recovery_area/HKCHR/archivelog/2006_07_14
1469224 flash_recovery_area/HKCHR/archivelog
6988 flash_recovery_area/HKCHR/backupset/2006_07_04/o1_mf_ncsnf_TAG20060704T1
74229_2bng1o0b_.bkp
876916 flash_recovery_area/HKCHR/backupset/2006_07_04/o1_mf_nnndf_TAG20060704T1
74229_2bng0cx4_.bkp
883908 flash_recovery_area/HKCHR/backupset/2006_07_04
883912 flash_recovery_area/HKCHR/backupset
2353144 flash_recovery_area/HKCHR
2353148 flash_recovery_area
[root@hrmsdb oracle]#
FLASH_RECOVERY_AREA空間使用了2.35GB
(6)檢視FLASH_RECOVERY_AREA空間中各部分使用情況
SQL> select * from v$recovery_file_dest;
NAME SPACE_LIMIT SPACE_USED SPACE_RECLAIMABLE NUMBER_OF_FILES
------------------------------------------------------------
/oracle/flash_recovery_area 2147483648 2134212608 0 35
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 69.97 0 40
BACKUPPIECE 30.01 0 2
IMAGECOPY 0 0 0
FLASHBACKLOG 0 0 0
已選擇6行。
發現ARCHIVELOG佔近70%,BACKUPPIRCR佔了30%,這樣FLASH_RECOVERY_AREA空間的空間已經被完全佔據了。
4、解決過程
根據資料庫目前可用儲存空間為200GB、FLASH_RECOVERY_AREA空間為2GB的實際情況,把FLASH_RECOVERY_AREA的空間修改為20GB。
SQL> alter system set DB_RECOVERY_FILE_DEST_SIZE=20g;
系統已更改。
SQL> select * from v$recovery_file_dest;
-------------------------------------------------------
NAME SPACE_LIMIT SPACE_USED SPACE_RECLAIMABLE NUMBER_OF_FILES
----------- ---------- ----------------- -------------
/oracle/flash_recovery_area 2.1475E+10 2264587776 0 38
這時再檢視日誌的狀態,發現REDO LOG處於正常的歸檔狀態。
SQL> select * from v$log;
GROUP# THREAD# SEQUENCE# BYTES MEMBERS ARC STATUS FIRST_CHANGE# FIRST_TIME
---------- ---------- ---------- ---------- ---------- ---
1 1 101 52428800 1 YES ACTIVE 3621973 24-7月 -06
2 1 102 52428800 1 NO CURRENT 3650399 25-7月 -06
3 1 100 52428800 1 YES INACTIVE 3611932 24-7月 -06
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 7.6 0 43
BACKUPPIECE 4.21 0 2
IMAGECOPY 0 0 0
FLASHBACKLOG 0 0 0
已選擇6行。
SQL>
總結
造成本次故障的原因由兩方面同時發生所造成的:
·其一是Flash_Recovery_Area空間預設安裝時比較小,只有2GB,容易用完;
·其二是由於採用歸檔方式透過Veritas備份,由於備份軟體沒有執行,造成歸檔日誌沒有及時刪除。
從本次故障解決處理中,我們可以得出經驗教訓:
·Oracle 10g資料庫物理空間管理方式與以前Oracle發生了變化,對歸檔日誌所在的Flash_Recovery_Area空間進行了另外限制;
·對資料庫系統管理員要對Oracle資料庫歸檔日誌、備份軟體執行狀況定期檢查,提前發現、處理可能發生的故障。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/12272958/viewspace-681037/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle ORA-00257故障解決辦法Oracle
- ORA-00257 錯誤分析及解決方法
- ORA-00257歸檔日誌寫滿的解決方法
- 解決ORA-00257:archiver error.Connect internal only, until freedHiveError
- 解決ORA-00257: archiver error. Connect internal only, until freedHiveError
- ORA-00257: archiver error. Connect internal only, until freed 解決方法HiveError
- Oracle db_recovery_file_dest空間不足報ora-00257問題解決Oracle
- char* 轉 LPCWSTR 解決方案
- 視訊轉碼解決方案
- (轉)解決XMind執行卡頓
- CA的安全解決方案(轉)
- 微軟解決方案架構 (轉)微軟架構
- 管理需要解決的矛盾(轉)
- ORA-00257歸檔日誌滿
- iOS螢幕旋轉解決方案iOS
- Sentinel哨兵模式解決故障轉移模式
- SVN clean失敗解決方法【轉】
- [轉]Android ANR 分析解決方法Android
- 解決你MCSE最大的困惑 (轉)
- EXP-00091解決方法(轉)
- 【轉】css解決相容的問題CSS
- 回溯法解決喝酒問題 (轉)
- 中文自定義字型列印解決!(轉)自定義字型
- 優先順序反轉+解決方案
- 優先順序反轉解決方案
- MySQL高效分頁解決方案集(轉)MySql
- 轉貼:xhost unable to open display解決方法
- mysql 插入中文亂碼解決方案 轉MySql
- 轉)用hanganalyze解決row cache lock
- (轉)用hanganalyze解決row cache lock
- MYSQL(解決方法):Client does not support authentication(轉)MySqlclient
- 績效管理整體解決方案(轉)
- 【轉載】ORA-27054 錯誤解決
- 解決BoundsChecker和VC打架的方法 (轉)
- Hibernate綜合查詢解決方案 (轉)
- 微軟解決方案架構(模組八) (轉)微軟架構
- 微軟解決方案架構(模組十) (轉)微軟架構
- oracle錯誤及解決方式集(轉)Oracle