sysaux表空间数据库块损坏/游离块的修复

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sysaux表空间数据库块损坏/游离块的修复相关的知识,希望对你有一定的参考价值。

  客户那边的数据库久无人维护,近期反映服务器空间不够。在检查服务器空间时,我又偶然发现了数据库的备份出现问题。

  经检查是数据库sysaux表空间存在一个坏块,存在坏块的表是WRH$_ENQUEUE_STAT,在测试库上查询数据后,我确定该表的数据对整个系统的运行影响不大。

  此时没有RMAN备份可以使用,block recover无法使用。于是决定将表删除重建。不过这么做之后,原有的数据块反而变成了游离块。为了修复游离块,我就在测试库上开始做测试。

1、模拟数据库损坏

1)模拟数据库的损坏可以使用ddbd,该工具的配置可以参考以下链接:

http://www.cnblogs.com/jyzhao/p/5139584.html

2)模拟要损坏的块

select file_id,block_id from dba_extents where segment_name=‘WRH$_ENQUEUE_STAT‘;

结果是file_id=2,block_id=4440

modify /x 62 file 2 block 4440 offset 255;

3)rman命令中,执行 backup validate database或者 backup validate datafile 2;

使用视图v$database_block_corruption查看backup操作发现的损坏的块。

select * from v$database_block_corruption;

4)表删除并且重建,发现file2 4440变成了游离块

select * from dba_extents where file_id=2 and 4440 between block_id-1 and block_id+1;#查询无数据

2、坏块修复

1)表空间修改为不能自动增长

alter database datafile 2 autoextend off;

2)在sysaux上创建实体表

create table test(id varchar(50)) tablespace sysaux;

3)插入数据直到报ORA01653的错误,连insert into test values(‘aaaaaaaaaa‘)都执行失败

insert into test values(‘aaaaaaaaaa‘);

commit;


insert into test

select *

from test;

commit;


4)再创建一张实体表

create table test_2(id varchar(50)) tablespace sysaux;

-- 查看file 2 block_id 4440 是否有数据

select * from dba_extents where file_id=2 and 4440 between block_id-1 and block_id+1;#模拟到此步,file 2 block_id 4440查询出来为test_2的数据。


5)删除测试表

drop table test_1;

drop table test;


6)表空间增长模式改为自动增长

alter database datafile 2 autoextend on;


7) 在RMAN中测试备份,可以正常执行全备。

RMAN>backup incremental level 0 database;


本文出自 “三国冷笑话” 博客,请务必保留此出处http://myhwj.blog.51cto.com/9763975/1884364

以上是关于sysaux表空间数据库块损坏/游离块的修复的主要内容,如果未能解决你的问题,请参考以下文章

SYSAUX表空间占用过大情况下的处理(AWR信息过多)

如何恢复 sysaux 表空间?

oracle SYSTEM,SYSAUX表空间过大

非标准数据块的表空间使用

非标准数据块的表空间使用

SYSAUX表空间满的解决方法