码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2016-12-20 21:18:50      阅读:224      评论:0      收藏:0      [点我收藏+]

标签:坏块   sysaux   游离块   ddbd   

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

  经检查是数据库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   游离块   ddbd   

原文地址:http://myhwj.blog.51cto.com/9763975/1884364

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!