检查数据块损坏(Block Corruption)

Oracle提供了很多工具用来检查数据块是否损坏,下面给大家介绍下
1.1DBVERIFY工具
数据块的物理错误可以通过DBV命令检查出来。
[oracle@pxboracle ~]$ dbv file=/u01/app/oracle/oradata/orcl/test01.dbf blocksize=8192
1.2RMAN的backup命令
RMAN的backup命令在备份时可以检查数据块的物理错误。
RMAN> backup datafile /u01/app/oracle/oradata/orcl/test01.dbf;
1.3RMAN的backup validate 命令
RMAN> backup validate database;        ---验证所有文件,包括数据文件、控制文件、参数文件
RMAN> backup validate datafile 4;        ---验证4号数据文件 
1.4DBMS_HM包
DBMS_HM包的RUN_CHECK可以检查数据块物理错误。它可以只检测一个区(extents)。
SYS@devdb>
  1 begin
  2  dbms_hm.run_check(
  3  check_name => 'Data Block Integrity Check',
  4  run_name => 'df4test',--检查4号文件中test表
  5  input_params => 'BLC_DF_NUM=4;BLC_BL_NUM=128');--'BLC_DF_NUM=4 表示4号文件,BLC_BL_NUM=128--块号
  6  end;
  7  /

 ---查看检查报告可以发现4号数据文件中块的损坏。
SYS@devdb>select dbms_hm.get_run_report('df4test') from dual;

---删除检测的所有的报告

SYS@devdb>
1. begin
2.dbms_hm.drop_schema();
3.end;
/

1.5 exp/expdp命令
exp/expdp命令导出数据库时会完全扫描每个数据块,所以也会检查出数据块的物理错误。
[oracle@devdb ~]$ exp scott/oracle owner=scott


1.6 使用DBMS_REPAIR包
DBMS_REPAIR包可以检查表和索引对象的数据块损坏情况。
begin
   dbms_repair.admin_tables(table_name => 'REPAIR_1',
                            table_type => dbms_repair.REPAIR_TABLE,
                            action     => dbms_repair.CREATE_ACTION);
end;
declare
   cor number;
begin
   dbms_repair.check_object(schema_name       => 'SYS',
                            object_name       => 'BIG',
                            repair_table_name => 'REPAIR_1',
                            corrupt_count     => cor);
   dbms_output.put_line(cor);
end;
select * from REPAIR_1;



本次只是给大家介绍了如何检测损坏的数据块,我们能找到损坏的数据块,下次的内容再给大家介绍如何修复我们检测到的损坏数据块。
pxboracle@live.com

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12798004/viewspace-1146441/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/12798004/viewspace-1146441/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
heap corruption detected: after normal block是一种内存错误,意味着在程序运行时,对于已分配的内存之后的内存发生了破坏。这个报错通常是由以下几种原因引起的: 1. 内存越界写入:在访问已分配内存之后的内存时,写入了超出内存边界的数据。这可能导致其他内存数据被覆盖或者指向其他非法的内存地址。 2. 释放已释放内存:在释放动态分配的内存后,继续对该内存进行读写操作。这样做可能导致其他高速缓存区或数据结构出现问题。 3. 重复释放内存:释放一个已被释放的内存。这种情况可能导致不可预料的结果,例如double free或者对已释放内存的访问。 4. 内存对齐错误:以错误的内存边界或对齐方式分配内存,例如使用不正确的对齐值进行内存分配。这可能会导致内存访问错误。 解决这个问题的方法包括: 1. 检查内存越界问题:检查代码是否存在写入已分配内存之后内存的错误,并确保所有的内存访问都在边界内。 2. 确保正确的内存释放:在释放内存之后,不再对该内存进行任何读写操作,并在需要的情况下将指针值设置为null。 3. 防止重复释放:确保每个内存只被释放一次,并在释放后将指针值设置为null,以防止误用。 4. 确保正确的内存对齐:在分配内存时,使用正确的内存边界和对齐方式,确保内存访问的正确性。 总之,修复heap corruption detected: after normal block错误需要仔细检查代码的内存操作,并确保操作正确,避免对未分配或已释放的内存进行访问和操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值