介绍Oracle数据库ORA-00257故障的解决办法


  • 来源:

2008-07-16 07:18:43 北京时间
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 ~]$

 

后台进程都正常运行。



发表评论

请文明参与讨论,禁止漫骂攻击。本站保留不刊登无关和不雅评论的权力。


用户名: 密码: 匿名

相关新闻
由于工程需要经常将客户的现场数据导出到公司的开发环境中,随着
在对数据库进行操作过程中我们可能会遇到这种情况,表中的数据可
根据NULL的定义,NULL表示的是未知,因此两个NULL比较的结果既不
ORACLE 数据库有三种标准的备份方法,它们分别为导出/导入(EXPO
近来公司技术,研发都在问我关于内存参数如何设置可以优化Oracle

广告
© 2008 The Czz5 Company. All Rights Reserved. 关于我们 - 联系我们 - 广告业务 - 网站地图 - 版权声明 - 友情连接 - 网站投稿 - 致信编辑