oracle数据坏块原因,对Oracle数据库坏块的理解

1.物理坏块和逻辑坏块

在数据库中有一个概念叫做数据块的一致性,Oracle的数据块的一致性包括了两个层次:物理一致性和逻辑一致性,如果一个数据块在这两个层次上存在不一致性,那就对应到了我们今天要要说的物理坏块和逻辑坏块。

在每一个数据块的头部有一个校验和字段,每当数据块要被写回磁盘前,Oracle都会重新计算 这个数据块的校验和,并记录到这个字段最终写会磁盘。下次数据块被读入内存,Oracle会重新 计算数据块的校验和,并和块头的字段相比较,如果有差异,Oracle就知道这个数据块有错误, 会报出ORA-1578错误。    通过校验和字段进行的检查就是物理一致性检查,这个功能可以让Oracle检查到所有底层的错误, 包括磁盘、存储、IO子系统,所以称做物理一致性检查。

在Oracle中每当要修改一个数据块中,会先对数据块内容做一个一致性检查(如检查记录 是否被不存在的食物锁定、记录和索引是否对应等)。如果这种一致性检查失败,就会抛出 ORA-600的Internal错误。当Oracle检查到数据块的逻辑一致性时,会尝试对数据块做 Cache Recovery,如果不能把数据块恢复到一致状态,Oracle就会把这个数据块标志为 Software Corrupt,当有查询访问到这数据块时,也会抛出前面ORA-1578错误。

物理一致性检查利用校验和字段工作,主要侧重于检查硬件故障,并不关心内容正确与否, 而逻辑一致性检查就是侧重于内容的检查,内容检查要比校验和检查复杂的多。 逻辑一致性检查内容要多于物理一致性检查。

2.发生坏块的原因

造成数据块损坏的原因多种多样,可是因为物理原因导致,也可能人为原因或Oracle bug导致。比较常见的人为原因异常关机、掉电、终止服务使进程异常终止,从而破坏数据的完整性,导致坏块的产生。发生数据块损坏的原因时,最典型的表现是遇到ORA-01578错误(比如在全表扫描时),有时也可能是ORA-600内部错误。

3.检查数据块的一致性

(1)使用初始化参数检查数据块的一致性

通过设置初始化参数db_block_checksum=true/false来启用、关闭物理一致性检查,启用该参数这会 增加1%~2%的负载,Oracle推荐启用该参数。在Oracle9i、10g中,默认是启用的。

通过设置参数db_block_checking=true可以启用数据块的逻辑一致性检查。启用该参数这会 增加1%~10%的负载,尤其DML操作越密集性能影响越大。在Oracle10g中这个参数 默认值是false,这将意味这数据库只对System表空间做逻辑一致性检查。

(2)DBV工具对数据块物理/逻辑性检查

详情:http://book.51cto.com/art/201108/287893.htm

(3)analyze命令检查数据块一致性

analyze命令有很多中用法,可以完成很多功能,具体可参考:http://blog.csdn.net/tianlesoftware/article/details/7055164

analyze命令检查对象一致性:   analyze table tablename validate structure cascade online(offline);

该命令同样会执行物理和逻辑一致性检查。除此之外,它还会检查表和索引条目的匹配性,检查分区表的记录是否在正确的分区中, 检查出的问题会放在USER_DUMP_DEST目录的trace文件中。

使用该命令注意一下几个问题:

*当检查分区表的记录是否在正确的分区时,可以把检查出来的记录的ROWID记录在一个特殊表中,这个表叫做invalid_rows,该表需要   使用utlvalid.sql脚本提前建立,检查语法:   analyze tablename validate structure into invalid_rows;

*如果检查索引,这个命令会检查数据块和索引的一致性,但是不会确认每条记录都有相应的索引项或这索引有对应的记录,  如果需要这种检查,需要使用cascade关键字。

*如果使用online子句,可以在DML操作时在线检查一致性,只是这时不会收集对象的统计信息;而如果使用offline表会被锁住。

(4)使用rman工具检查

*检查数据文件

backup check logical validate [database];

*检查单个数据文件

backup check logical validate datafile 1,2;

*检查整个库

backup check logical validate database    检查的结果放在v$database_block_corruption这个动态视图中。

*这个命令对系统性能有一定的影响。

(5)使用dbms_repair.check_object方法执行检查

详细可参考:http://blog.itpub.net/8494287/viewspace-1357457/

(6)利用exp工具导出整个数据库可以检测坏块

导出命令在执行中会报ORA-01578错误,在这错误提示中会提示那个文件号的文件以及这个文件中的哪个块被损坏,如:ORA—01578:ORACLE 数据块损坏(文件号 4,块号 35)。利用exp工具进行检查坏块也局限性,对一些类型的坏块是检测不出来的如:HWM以上的坏块是不会发现的、索引中存在的坏块是不会发现的、数据字典中的坏块是不会发现的。

-----待续

原文:http://www.cnblogs.com/myrunning/p/4430304.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle数据库数据字典是一个包含Oracle数据库中所有对象的元数据信息的特殊数据库对象。它存储了数据库中的表、视图、索引、约束、触发器等各种对象的定义和属性信息。 数据字典是Oracle数据库的一个重要组成部分,它存储在数据文件中,和其他数据库对象一样可以被备份和恢复。数据字典的存储结构是基于表和索引的,这使得它可以高效地进行查询和检索。 通过查询数据字典,我们可以获取到数据库中的各种对象的定义、属性、依赖关系、统计信息等信息。这些信息对于数据库管理员和开发人员来说非常重要,可以帮助他们更好地理解和管理数据库。 在Oracle数据库中,我们可以使用SQL语句查询数据字典。例如,我们可以使用以下语句查询数据库中的表信息: SELECT table_name, tablespace_name, num_rows FROM dba_tables; 这个查询语句会返回数据库中的所有表的名称、所属表空间和行数。 此外,我们还可以使用数据字典来查询索引、视图、约束、触发器等对象的信息。通过查询数据字典,我们可以了解数据库中的对象之间的依赖关系,比如一个表被哪些视图引用、一个触发器对哪些表进行操作等。 总之,Oracle数据库数据字典是一个非常有用的工具,它存储了数据库中各种对象的元数据信息,可以帮助数据库管理员和开发人员更好地管理和理解数据库。通过查询数据字典,我们可以获取到数据库中的对象的定义、属性、依赖关系等信息,提供了非常重要的参考和帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值