标签云
asm恢复 bbed bootstrap$ dul kcbzib_kcrsds_1 kccpb_sanity_check_2 kcratr_nab_less_than_odr kgegpa MySQL恢复 ORA-00312 ORA-00704 ORA-00742 ORA-01110 ORA-01190 ORA-01200 ORA-01555 ORA-01578 ORA-01595 ORA-600 2662 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 ORACLE恢复 Oracle 恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (106)
- 数据库 (1,804)
- DB2 (22)
- MySQL (80)
- Oracle (1,639)
- Data Guard (53)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (166)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (69)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (29)
- Oracle备份恢复 (612)
- Oracle安装升级 (102)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (86)
- PostgreSQL (33)
- pdu工具 (7)
- PostgreSQL恢复 (11)
- SQL Server (32)
- SQL Server恢复 (13)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (43)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (26)
-
最近发表
- expdp dmp 导出不完整导入ORA-39059 ORA-39246 故障抢救数据
- mysql drop database 恢复思路
- PRVG-11975 : The I/O scheduler parameter of device “/dev/sdm” did not match the expected value on nodes
- obet(Oracle Block Editor Tool)第二版发布
- Oracle数据块编辑工具( Oracle Block Editor Tool)-obet
- Oracle坏块修复工具:Patch_blk
- ORA-01172 ORA-01151故障处理
- C_OBJ#_INTCOL#坏块导致数据库无法open故障处理
- ORA-600 kkkicreatecgmap:!efn3
- Oracle 19c 202510补丁(RUs+OJVM)-19.29
- 记录一次raid恢复之后数据库故障处理(ora-01200,ORA-26101,ORA-600)
- nbu备份文件img格式直接rman恢复
- ORA-600 kokasgi1故障处理(sys被重命名)
- Patch_SCN for Linux 功能完善
- ORA-600 2662错误处理-202510
- system表空间丢失部分文件恢复
- arm环境vg损坏mysql数据库恢复
- redhat系列7/8进入单用户模式
- Failed to open \EFI\redhat\grubx64.efi – Not Found 故障处理
- 11.2.0.4升级到19c详细操作过程
标签归档:坏块修复工具
Oracle坏块修复工具:Patch_blk
在win平台上开发了Oracle Recovery Tools小工具,可以实现坏块的快速恢复功能

具体参考相关文章:自研Oracle恢复小工具
由于之前工具使用c#开发不太方便实现跨平台(而且图形化在linux等操作系统上使用起来不方便),现在使用c语言写了小工具:Patch_blk(主要是seq_kcbh tailchk checksum类似坏块处理),模拟两个坏块
BBED> verify DBVERIFY - Verification starting FILE = /u01/app/oracle/oradata/xifenfei/system01.dbf BLOCK = 521 Block 521 is corrupt Corrupt block relative dba: 0x00400209 (file 0, block 521) Fractured block found during verification Data in bad block: type: 6 format: 2 rdba: 0x00400209 last change scn: 0x0000.000001d7 seq: 0x1 flg: 0x06 spare1: 0x0 spare2: 0x0 spare3: 0x0 consistency value in tail: 0x01d706fe check value in block header: 0x5205 computed block checksum: 0x0 DBVERIFY - Verification complete Total Blocks Examined : 1 Total Blocks Processed (Data) : 0 Total Blocks Failing (Data) : 0 Total Blocks Processed (Index): 0 Total Blocks Failing (Index): 0 Total Blocks Empty : 0 Total Blocks Marked Corrupt : 1 Total Blocks Influx : 2 Message 531 not found; product=RDBMS; facility=BBED BBED> verify block 522 DBVERIFY - Verification starting FILE = /u01/app/oracle/oradata/xifenfei/system01.dbf BLOCK = 522 Block 522 is corrupt Corrupt block relative dba: 0x0040020a (file 0, block 522) Fractured block found during verification Data in bad block: type: 6 format: 2 rdba: 0x0040020a last change scn: 0x0000.000001d7 seq: 0xff flg: 0x06 spare1: 0x0 spare2: 0x0 spare3: 0x0 consistency value in tail: 0x01d70601 check value in block header: 0x1e16 computed block checksum: 0x0 DBVERIFY - Verification complete Total Blocks Examined : 1 Total Blocks Processed (Data) : 0 Total Blocks Failing (Data) : 0 Total Blocks Processed (Index): 0 Total Blocks Failing (Index): 0 Total Blocks Empty : 0 Total Blocks Marked Corrupt : 1 Total Blocks Influx : 2 Message 531 not found; product=RDBMS; facility=BBED
配置坏块修复列表文件
[root@iZbp11c0qyuuo1gr7j98upZ tmp]# cat 1.txt /u01/app/oracle/oradata/xifenfei/system01.dbf 521 8192 N /u01/app/oracle/oradata/xifenfei/system01.dbf 522 8192 Y --列表文件说明 数据文件路径 文件号 数据块大小 是否人工干预(N表示不需要,Y表示需要)
执行修复操作
[root@iZbp11c0qyuuo1gr7j98upZ tmp]# ./Patch_blk 1.txt ===== Processing line 1 ===== ===================================================== Processing: File=/u01/app/oracle/oradata/xifenfei/system01.dbf, Block=521, Size=8192, Mode=N ===================================================== === Step 1: Check seq_kcbh === Current value: 0x01 [OK] seq_kcbh is normal === Step 2: Check tailchk === Current (reversed): 0x01D706FE Expected (reversed): 0x01D70601 [Auto-repair] tailchk mismatch, will fix [Backup] Block saved to: ./20251104_230616/system01.dbf_block521 [Success] tailchk fixed [Verify] New tailchk (reversed): 0x01D70601 === Step 3: Check checksum === Current checksum: 0x0552 Computed checksum: 0xFA52 [Auto-repair] Checksum mismatch, will fix [Success] Checksum fixed [Verify] New checksum: 0xFA52 === Step 4: Final Verification === seq_kcbh: 0x01 (not 0xFF: PASS) tailchk: 0x01D70601 (expected 0x01D70601: PASS) Checksum: 0xFA52 (expected 0xFA52: PASS) [Result] Block repair completed successfully ===== Processing line 2 ===== ===================================================== Processing: File=/u01/app/oracle/oradata/xifenfei/system01.dbf, Block=522, Size=8192, Mode=Y ===================================================== === Step 1: Check seq_kcbh === Current value: 0xFF [WARNING] Block is marked as BAD. Repair? (yes/no): y [Backup] Block saved to: ./20251104/system01.dbf_block522 [Success] seq_kcbh updated to 0x01 === Step 2: Check tailchk === Current (reversed): 0x01D70601 Expected (reversed): 0x01D70601 [OK] tailchk is normal === Step 3: Check checksum === Current checksum: 0x161E Computed checksum: 0xE81E [WARNING] Checksum mismatch. Repair? (yes/no): y [Success] Checksum fixed [Verify] New checksum: 0xE81E === Step 4: Final Verification === seq_kcbh: 0x01 (not 0xFF: PASS) tailchk: 0x01D70601 (expected 0x01D70601: PASS) Checksum: 0xE81E (expected 0xE81E: PASS) [Result] Block repair completed successfully ===================================== Processing complete. Total: 2 Modify Success: 2 Modify None: 0 Skipped/Failed: 0 Blocks Backed Up: 2 =====================================
在修复坏块之前会对相关block进行备份
[root@iZbp11c0qyuuo1gr7j98upZ 20251104]# ls -ltra total 24 -rw-r--r-- 1 root root 8192 Nov 4 22:42 system01.dbf_block521 -rw-r--r-- 1 root root 8192 Nov 4 22:42 system01.dbf_block522 drwxr-xr-x 2 root root 4096 Nov 4 22:42 . drwxrwxrwt. 14 root root 4096 Nov 4 23:39 .. [root@iZbp11c0qyuuo1gr7j98upZ 20251104]#
Patch_blk修复坏块之后,检查坏块正常
BBED> verify DBVERIFY - Verification starting FILE = /u01/app/oracle/oradata/xifenfei/system01.dbf BLOCK = 521 DBVERIFY - Verification complete Total Blocks Examined : 1 Total Blocks Processed (Data) : 1 Total Blocks Failing (Data) : 0 Total Blocks Processed (Index): 0 Total Blocks Failing (Index): 0 Total Blocks Empty : 0 Total Blocks Marked Corrupt : 0 Total Blocks Influx : 0 Message 531 not found; product=RDBMS; facility=BBED BBED> verify block 522 DBVERIFY - Verification starting FILE = /u01/app/oracle/oradata/xifenfei/system01.dbf BLOCK = 522 DBVERIFY - Verification complete Total Blocks Examined : 1 Total Blocks Processed (Data) : 1 Total Blocks Failing (Data) : 0 Total Blocks Processed (Index): 0 Total Blocks Failing (Index): 0 Total Blocks Empty : 0 Total Blocks Marked Corrupt : 0 Total Blocks Influx : 0 Message 531 not found; product=RDBMS; facility=BBED
对于不太熟悉bbed的客户,可以通过这个工具快速实现常见坏块类型恢复

加我QQ(107644445)

