设为首页 加入收藏

TOP

介绍Oracle自带的一些ASM维护工具(kfod/kfed/amdu)(二)
2015-11-21 02:07:05 来源: 作者: 【 】 浏览:2
Tags:介绍 Oracle 自带 一些 ASM 维护 工具 kfod/kfed/amdu
on

n/ohdr KFOD header suppression[nohdr=TRUE/(FALSE)]

o/p KFOD options type[OP=DISKS/CANDIDATES/MISSING/GROUPS/INSTS/VERSION/CLIENTS/RM/RMVERS/DFLTDSTR/GPNPDSTR/METADATA/ALL]

p/file ASM parameter file[pfile=parameterfile]

s/tatus Include disk header status[status=TRUE/(FALSE)]

v/erbose KFOD verbose errors[verbose=TRUE/(FALSE)]

我们可以看到,有大量的参数,几乎可以轻松的查看ASM的所有信息,如我们以前要查询ASM的磁盘空间大小和剩余量,必须通过登录实例访问视图,现在就可以直接通过kfod工具查询,如下:

l 查看磁盘组信息

[oracle@rac01~]$ kfod di=all op=groups

--------------------------------------------------------------------------------

Group Size Free Redundancy Name

================================================================================

1: 16378 Mb 14070 Mb EXTERN DATA

2: 509 Mb 459 Mb EXTERN ARCH

l 查看磁盘组的组成

[oracle@rac01~]$ kfod di=all group=diskgroup ds=true

--------------------------------------------------------------------------------

Disk Size Path DiskGroup User Group

================================================================================

1: 8189 Mb /dev/asm-disk1 DATA oracle dba

2: 8189 Mb /dev/asm-disk2 DATA oracle dba

3: 509 Mb /dev/asm-disk3 ARCH oracle dba

3.2. kfed介绍

kfod只是可以通过操作系统直接查看ASM的信息,但是前面我们说了,ASM最易出现问题的不是存储数据的本身,而是ASM磁盘头,那如何访问和维护磁盘头呢?这就要用到我们介绍的kfed工具。KFED是ASM自带的一个未公开的工具,它可以对ASM元数据进行一系列的操作,重要的是它能够在ASM无法启动的时候也可以工作,对修复一些关键错误非常有用(前面介绍的kfod必须在ASM启动的状态下访问),我们同样先来看下帮助信息,如下:

[oracle@rac01~]$ kfed -h

as/mlib ASM Library [asmlib='lib']

aun/um AU number to examine or update[AUNUM=number]

aus/z Allocation Unit size in bytes[AUSZ=number]

blkn/um Block number to examine or update[BLKNUM=number]

blks/z Metadata block size in bytes[BLKSZ=number]

ch/ksum Update checksum before each write[CHKSUM=YES/NO]

cn/t Count of AUs to process[CNT=number]

de/v ASM device to examine or update[DEV=string]

dm/pall Don't suppress repeated lines whendumping corrupt blocks [DMPALL=YES/NO]

o/p KFED operation type[OP=READ/WRITE/MERGE/REPAIR/NEW/FORM/FIND/STRUCT]

p/rovnm Name for provisioning purposes[PROVNM=string]

s/eek AU number to seek to [SEEK=number]

te/xt File name for translated block text[TEXT=string]

ty/pe ASM metadata block type number[TYPE=number]

kfed可以跳过ASM实例直接访问磁盘,这就可以在一些非常规的环境下,如ASM关闭,磁盘组无法mount等对ASM的相关信息进行访问,在加上其具备的修改功能,可以利用其对ASM进行修复操作,要想了解kfed的修复方法,我们首先来了解下ASM磁盘头,前面我们通过kfod知道了有/dev/asm-disk1、/dev/asm-disk2、/dev/asm-disk3个磁盘作为ASM的磁盘组所使用,我们又知道,磁盘头的信息存放在每个磁盘0号AU的位置第0号数据块中,那么现在我们就以其中的一个来看一下它的磁盘头到底存储了那些信息,如下:

[oracle@rac01~]$ kfed read /dev/asm-disk1 aun=0 blkn=0

【01】kfbh.endian: 1 ; 0x000: 0x01

【02】kfbh.hard: 130 ; 0x001: 0x82

【03】kfbh.type: 1 ; 0x002:KFBTYP_DISKHEAD

【04】kfbh.datfmt: 1 ; 0x003: 0x01

【05】kfbh.block.blk: 0 ; 0x004: blk=0

【06】kfbh.block.obj: 2147483648 ; 0x008: disk=0

【07】kfbh.check: 875080645 ; 0x00c:0x3428abc5

【08】kfbh.fcn.base: 4892 ; 0x010: 0x0000131c

【09】kfbh.fcn.wrap: 0 ; 0x014: 0x00000000

【10】kfbh.spare1: 0 ; 0x018: 0x00000000

【11】kfbh.spare2: 0 ; 0x01c: 0x00000000

【12】kfdhdb.driver.provstr: ORCLDISK ; 0x000: length=8

【13】kfdhdb.driver.reserved[0]: 0 ; 0x008: 0x00000000

【14】kfdhdb.driver.reserved[1]: 0 ; 0x00c: 0x00000000

【15】kfdhdb.driver.reserved[2]: 0 ; 0x010: 0x00000000

【16】kfdhdb.driver.reserved[3]: 0 ; 0x014: 0x00000000

【17】kfdhdb.driver.reserved[4]: 0 ; 0x018: 0x00000000

【18】kfdhdb.driver.reserved[5]: 0 ; 0

首页 上一页 1 2 3 4 5 6 7 下一页 尾页 2/8/8
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇为什么要学习Oracle技术? 下一篇oracle中往varchar2格式的字段中..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: