重庆思庄Oracle、Redhat认证学习论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1568|回复: 0
打印 上一主题 下一主题

[Oracle] 出现坏块的原因

[复制链接]
跳转到指定楼层
楼主
发表于 2022-8-3 14:31:09 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
1.物理坏块和逻辑坏块

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

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

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

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


2.发生坏块的原因

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


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 支持支持 反对反对
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|重庆思庄Oracle、Redhat认证学习论坛 ( 渝ICP备12004239号-4 )

GMT+8, 2024-11-26 02:32 , Processed in 0.094952 second(s), 20 queries .

重庆思庄学习中心论坛-重庆思庄科技有限公司论坛

© 2001-2020

快速回复 返回顶部 返回列表