如果自己搞不定可以找诗檀软件专业ORACLE数据库修复团队成员帮您恢复!
诗檀软件专业数据库修复团队
服务热线 : 13764045638 QQ号:47079569 邮箱:service@parnassusdata.com
概述
- 注意– 不要在生产系统上运行这些命令,因为很容易就会损坏数据
- ASM 11.1.0.7版本及更高版本中,ASM磁盘头块在分配单元1中的倒数第二个ASM元数据块中有备份
Kfed 参数
- aun -读取分配单位(AU)号码。默认值是AU0,或ASM磁盘的开始
- aus – AU大小. 默认为1048576 (1MB). 从非默认AU大小的磁盘组读取时,指定AUS。
- blkn – 读块号。默认值是块0,或者AU的第一个块。
- dev – ASM磁盘或设备名称。注意,关键字dev可以省略,但ASM磁盘名称是必须的。
了解ASM 磁盘布局
Read ASM disk header block from AU[0]
[root@grac41 Desktop]# kfed read /dev/asm_test_1G_disk1 | egrep ‘name|size|type’
kfbh.type: 1 ; 0x002: KFBTYP_DISKHEAD <– ASM disk header
kfdhdb.dskname: TEST_0000 ; 0x028: length=9 <– ASM disk name
kfdhdb.grpname: TEST ; 0x048: length=4 <– ASM DG name
kfdhdb.fgname: TEST_0000 ; 0x068: length=9 <– ASM Failgroup
kfdhdb.capname: ; 0x088: length=0
kfdhdb.secsize: 512 ; 0x0b8: 0x0200 <– Disk sector size
kfdhdb.blksize: 4096 ; 0x0ba: 0x1000 <– ASM block size
kfdhdb.ausize: 1048576 ; 0x0bc: 0x00100000 <– AU size : 1 Mbyte
kfdhdb.dsksize: 1023 ; 0x0c4: 0x000003ff <– ASM disk size : 1 GByte
Check ASM block types for the first 2 AUs
AU[0] :
[root@grac41 Desktop]# kfed find /dev/asm_test_1G_disk1
Block 0 has type 1
Block 1 has type 2
Block 2 has type 3
Block 3 has type 3
Block 4 has type 3
Block 5 has type 3
Block 6 has type 3
Block 7 has type 3
Block 8 has type 3
Block 9 has type 3
Block 10 has type 3
..
Block 252 has type 3
Block 253 has type 3
Block 254 has type 3
Block 255 has type 3
AU[1] :
[root@grac41 Desktop]# kfed find /dev/asm_test_1G_disk1 aun=1
Block 256 has type 17
Block 257 has type 17
Block 258 has type 13
Block 259 has type 18
Block 260 has type 13
..
Block 508 has type 13
Block 509 has type 13
Block 510 has type 1
Block 511 has type 19
Summary :
–> Disk header size is 512 bytes
AU size = 1Mbyte –> AU block size = 4096
This translates to 1048576 / 4096 = 256 blocks to read an AU ( start with block 0 – 255 )
Block 510 and block 0 storing an ASM disk header ( == type 1 )
Run the kfed command below if you interested in a certain ASM block type ( use output from kfed find to the type info )
[root@grac41 Desktop]# kfed read /dev/asm_test_1G_disk1 aun=1 blkn=255 | egrep ‘type’
kfbh.type: 19 ; 0x002: KFBTYP_HBEAT
Some ASM block types
[root@grac41 Desktop]# kfed read /dev/asm_test_1G_disk1 aun=0 blkn=0 | egrep ‘type’
kfbh.type: 1 ; 0x002: KFBTYP_DISKHEAD
kfbh.type: 2 ; 0x002: KFBTYP_FREESPC
kfbh.type: 3 ; 0x002: KFBTYP_ALLOCTBL
kfbh.type: 5 ; 0x002: KFBTYP_LISTHEAD
kfbh.type: 13 ; 0x002: KFBTYP_PST_NONE
kfbh.type: 18 ; 0x002: KFBTYP_PST_DTA
kfbh.type: 19 ; 0x002: KFBTYP_HBEAT
在AU[0] 用 kfed修复磁盘头块
- ASM 11.1.0.7版本及更高版本中,ASM磁盘头块在分配单元1中的倒数第二个ASM元数据块中有备份
Verify ASM DISK Header block located in AU[0] and AU[1]
AU[0] :
[root@grac41 Desktop]# kfed read /dev/asm_test_1G_disk1 aun=0 blkn=0 | egrep ‘name|size|type’
kfbh.type: 1 ; 0x002: KFBTYP_DISKHEAD
kfdhdb.dskname: TEST_0000 ; 0x028: length=9
kfdhdb.grpname: TEST ; 0x048: length=4
kfdhdb.fgname: TEST_0000 ; 0x068: length=9
kfdhdb.capname: ; 0x088: length=0
kfdhdb.secsize: 512 ; 0x0b8: 0x0200
kfdhdb.blksize: 4096 ; 0x0ba: 0x1000
kfdhdb.ausize: 1048576 ; 0x0bc: 0x00100000
kfdhdb.dsksize: 1023 ; 0x0c4: 0x000003ff
AU[1] :
[root@grac41 Desktop]# kfed read /dev/asm_test_1G_disk1 aun=1 blkn=254 | egrep ‘name|size|type’
kfbh.type: 1 ; 0x002: KFBTYP_DISKHEAD
kfdhdb.dskname: TEST_0000 ; 0x028: length=9
kfdhdb.grpname: TEST ; 0x048: length=4
kfdhdb.fgname: TEST_0000 ; 0x068: length=9
kfdhdb.capname: ; 0x088: length=0
kfdhdb.secsize: 512 ; 0x0b8: 0x0200
kfdhdb.blksize: 4096 ; 0x0ba: 0x1000
kfdhdb.ausize: 1048576 ; 0x0bc: 0x00100000
kfdhdb.dsksize: 1023 ; 0x0c4: 0x000003ff
Erase Disk header block in first AU ( aun=0 blkn=0 )
# dd if=/dev/zero of=/dev/asm_test_1G_disk1 bs=4096 count=1
Verify ASM disk header
# kfed read /dev/asm_test_1G_disk1 aun=0 blkn=0
kfbh.type: 0 ; 0x002: KFBTYP_INVALID
KFED-00322: Invalid content encountered during block traversal: [kfbtTraverseBlock][Invalid OSM block type][][0]
–> Corrupted ASM disk header detected in AU [0]
Repair disk header in AU[0] with kfed
[grid@grac41 ASM]$ kfed repair /dev/asm_test_1G_disk1
[grid@grac41 ASM]$ kfed read /dev/asm_test_1G_disk1 aun=0 blkn=0
kfbh.type: 1 ; 0x002: KFBTYP_DISKHEAD
kfdhdb.dskname: TEST_0000 ; 0x028: length=9
kfdhdb.grpname: TEST ; 0x048: length=4
kfdhdb.fgname: TEST_0000 ; 0x068: length=9
kfdhdb.capname: ; 0x088: length=0
kfdhdb.secsize: 512 ; 0x0b8: 0x0200
kfdhdb.blksize: 4096 ; 0x0ba: 0x1000
kfdhdb.ausize: 1048576 ; 0x0bc: 0x00100000
kfdhdb.dsksize: 1023 ; 0x0c4: 0x000003ff
–> kfed repair worked – Disk header restored
kfed可以修复存储在第二个AU中的磁盘头块吗 ?
Delete Disk header block in AU[1]
First use dd to figure out whether we are getting the correct block
[grid@grac41 ASM]$ dd if=/dev/asm_test_1G_disk1 of=- bs=4096 count=1 skip=510 ; strings block1
1+0 records in
1+0 records out
4096 bytes (4.1 kB) copied, 0.000464628 s, 8.8 MB/s
ORCLDISK
TEST_0000
TEST
TEST_0000
–> looks like an ASM disk header – go ahead and erase that block
[grid@grac41 ASM]$ dd if=/dev/zero of=/dev/asm_test_1G_disk1 bs=4096 count=1 seek=510
1+0 records in
1+0 records out
4096 bytes (4.1 kB) copied, 0.00644028 s, 636 kB/s
Verify ASM disk header block in AU[1]
[grid@grac41 ASM]$ kfed read /dev/asm_test_1G_disk1 aun=1 blkn=254
kfbh.type: 0 ; 0x002: KFBTYP_INVALID
KFED-00322: Invalid content encountered during block traversal: [kfbtTraverseBlock][Invalid OSM block type][][0]
–> Corrupted ASM disk header detected
[grid@grac41 ASM]$ kfed repair /dev/asm_test_1G_disk1
KFED-00320: Invalid block num1 = [0], num2 = [1], error = [endian_kfbh]
–> kfed repair doesn’ work
Repair block with dd
grid@grac41 ASM]$ dd if=/dev/asm_test_1G_disk1 bs=4096 count=1 of=/dev/asm_test_1G_disk1 bs=4096 count=1 seek=510
1+0 records in
1+0 records out
4096 bytes (4.1 kB) copied, 0.0306682 s, 134 kB/s
[grid@grac41 ASM]$ kfed read /dev/asm_test_1G_disk1 aun=0 blkn=0
kfbh.type: 1 ; 0x002: KFBTYP_DISKHEAD
kfdhdb.dskname: TEST_0000 ; 0x028: length=9
kfdhdb.grpname: TEST ; 0x048: length=4
kfdhdb.fgname: TEST_0000 ; 0x068: length=9
kfdhdb.capname: ; 0x088: length=0
kfdhdb.secsize: 512 ; 0x0b8: 0x0200
kfdhdb.blksize: 4096 ; 0x0ba: 0x1000
kfdhdb.ausize: 1048576 ; 0x0bc: 0x00100000
kfdhdb.dsksize: 1023 ; 0x0c4: 0x000003ff
# kfed read /dev/asm_test_1G_disk1 aun=1 blkn=254
kfbh.type: 1 ; 0x002: KFBTYP_DISKHEAD
kfdhdb.dskname: TEST_0000 ; 0x028: length=9
kfdhdb.grpname: TEST ; 0x048: length=4
kfdhdb.fgname: TEST_0000 ; 0x068: length=9
kfdhdb.capname: ; 0x088: length=0
kfdhdb.secsize: 512 ; 0x0b8: 0x0200
kfdhdb.blksize: 4096 ; 0x0ba: 0x1000
kfdhdb.ausize: 1048576 ; 0x0bc: 0x00100000
kfdhdb.dsksize: 1023 ; 0x0c4: 0x000003ff
Summary:
to fix the backup block or the ASM disk header in AU 1 block you need to use dd
Comment