ORA-48104: read mismatch on blocks requested and returned, [string], [string] ORACLE 报错 故障修复 远程处理

文档解释

ORA-48104: read mismatch on blocks requested and returned, [string], [string]

Cause: There was a mismatch between the number of blocks requested for reading and the number of blocks actually returned.

Action: Check the file to make sure there are no partial blocks.

ORA-48104是Oracle的一个表空间/数据块失败错误。它指出请求的数据块和返回的数据块不匹配。

这意味着以下两个数据块文件中的一个或两个被替换,或者一个文件丢失或不正确:已发出请求的块,以及实际返回的块。

此错误可能是由以下造成的:

* 损坏的磁盘驱动器;

* 内存问题;

* 非正常关闭数据库;

* 背景进程受到系统故障影响;

* 数据文件受到磁盘程序的干扰;

* 数据库被重新启动而没有正确的文件头;

* 格式不正确的软件副本;

* 网络服务暴力破坏;

* 代理备份过程中的问题;

* 由于网络不活动而发生I/O超时;

一般处理方法及步骤

1. 通过诊断日志检查块来源文件(FNO)、块号(BNO)和失败原因,以及更多关于块不匹配的细节信息。

2. 检查错误日志,确定失败原因,并查看是否存在损坏的磁盘驱动器、OS损坏、内存问题等。

3. 执行系统检查,以确定是否存在问题的底层原因。如:检查OS日志文件,查看服务器是否 掉线等。

4. 针对硬件问题,确认数据库位于何处,重新校正硬件,重新配置相关设备,并重新挂载相关fs 。

5. 将块移动到其他位置。通过修复块使损坏的块被移动到另一个位置。简单来说,只要存在损坏的块,就可以尝试移动它们到一个新的位置上。

6. 使用数据库完整性检查脚本对所有数据文件进行前后处理比较,直到所有损坏块都被更正或移动。

7.最后,如果可能的话,完成一次完整的备份以确保数据完整性。


数据运维技术 » ORA-48104: read mismatch on blocks requested and returned, [string], [string] ORACLE 报错 故障修复 远程处理