Oracle ASM 翻译系列第二十弹:ASM Internal ASM file number 7

简介:

ASM file number 7

ASM元信息7号文件,是ASM的逻辑卷目录,用于跟踪与ADVM有关的文件。

ASM动态逻辑卷设备是由ASM动态逻辑卷构建的。一个磁盘组中可以配置一个或多个ASM动态逻辑卷设备。ASM集群文件系统通过ADVM接口构建在ASM磁盘组之上。ADVM像数据库一样,也是ASM的一个客户端。当一个逻辑卷被访问时,相应的ASM文件会被打开并且ASM extent的信息会被发送到ADVM驱动。

有两种与ADVM逻辑卷相关的文件类型:

· ASMVOL:逻辑卷文件,作为逻辑卷存储的容器

· ASMVDRL:包含脏数据记录区域信息的文件。重新同步镜像数据时会用到此文件。

Turn up the ADVM volume

为ADVM创建一个单独的磁盘组并不是必须的,但这样做确实是有意义的,通过这种方式,可以把数据库文件与ACFS文件隔离开。看几个例子。

SQL> create diskgroup ACFS

disk 'ORCL:ASMDISK5', 'ORCL:ASMDISK6'

attribute 'COMPATIBLE.ASM' = '11.2', 'COMPATIBLE.ADVM' = '11.2';

Diskgroup created.

要创建逻辑卷,首先需要有一个磁盘组,上面创建了一个名称为acfs的磁盘组。为了能在磁盘组中创建逻辑卷,磁盘组的COMPATIBLE.ASM与COMPATIBLE.ADVM必须设置为11.2或以上,同时ADVM/ACFS驱动要被加载(在集群环境中,已经默认加载,而在单实例环境中,需要手动加载)。

做到以上要求后,就可以在磁盘组中创建逻辑卷了。

$ asmcmd volcreate -G ACFS -s 2G ACFS_VOL1


$ asmcmd volcreate -G ACFS -s 2G ACFS_VOL2


$ asmcmd volinfo -a

Diskgroup Name: ACFS


 Volume Name: ACFS_VOL1

 Volume Device: /dev/asm/acfs_vol1-159

 State: ENABLED

 Size (MB): 2048

 Resize Unit (MB): 32

 Redundancy: MIRROR

 Stripe Columns: 4

 Stripe Width (K): 128

 Usage:

 Mountpath:


 Volume Name: ACFS_VOL2

 Volume Device: /dev/asm/acfs_vol2-159

 State: ENABLED

 Size (MB): 2048

 Resize Unit (MB): 32

 Redundancy: MIRROR

 Stripe Columns: 4

 Stripe Width (K): 128

 Usage:

 Mountpath:


$

到现在,还没有相应的挂载目录与逻辑卷相关联,所以还不能使用它们。这时,我们可以先看看ADVM逻辑卷元信息,我们先从逻辑卷目录获取其所在的分配单元。

SQL> SELECT x.xnum_kffxp "Extent",

 x.au_kffxp "AU",

 x.disk_kffxp "Disk #",

 d.name "Disk name"

FROM x$kffxp x, v$asm_disk_stat d

WHERE x.group_kffxp=d.group_number

 and x.disk_kffxp=d.disk_number

 and x.group_kffxp=2

 and x.number_kffxp=7

ORDER BY 1, 2;


    Extent         AU     Disk # Disk name

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

         0         53          1 ASMDISK6

         0         53          0 ASMDISK5

接下来,使用kfed工具查看真实的元信息。

$ kfed read /dev/oracleasm/disks/ASMDISK5 aun=53 | more

kfbh.endian:                          1 ; 0x000: 0x01

kfbh.hard:                          130 ; 0x001: 0x82

kfbh.type:                           22 ; 0x002: KFBTYP_VOLUMEDIR

...

kfvvde.entry.incarn:                  1 ; 0x024: A=1 NUMM=0x0

kfvvde.entry.hash:                    0 ; 0x028: 0x00000000

kfvvde.entry.refer.number:   4294967295 ; 0x02c: 0xffffffff

kfvvde.entry.refer.incarn:            0 ; 0x030: A=0 NUMM=0x0

kfvvde.volnm:           ++AVD_DG_NUMBER ; 0x034: length=15

kfvvde.usage:                           ; 0x054: length=0

kfvvde.dgname:                          ; 0x074: length=0

kfvvde.clname:                          ; 0x094: length=0

kfvvde.mountpath:                       ; 0x0b4: length=0

kfvvde.drlinit:                       0 ; 0x4b5: 0x00

kfvvde.pad1:                          0 ; 0x4b6: 0x0000

kfvvde.volfnum.number:                0 ; 0x4b8: 0x00000000

kfvvde.volfnum.incarn:                0 ; 0x4bc: 0x00000000

kfvvde.drlfnum.number:                0 ; 0x4c0: 0x00000000

kfvvde.drlfnum.incarn:                0 ; 0x4c4: 0x00000000

kfvvde.volnum:                        0 ; 0x4c8: 0x0000

kfvvde.avddgnum:                    159 ; 0x4ca: 0x009f

kfvvde.extentsz:                      0 ; 0x4cc: 0x00000000

kfvvde.volstate:                      4 ; 0x4d0: D=0 C=0 R=1

...

上面的输出信息显示了53号AU的block 0.它只包含了ADVM逻辑卷的标记(++AVD_DG_NUMBER),而真正的逻辑卷的信息其实位于block 1及以后。

$ kfed read /dev/oracleasm/disks/ASMDISK5 aun=53 blkn=1 | more

kfbh.endian:                          1 ; 0x000: 0x01

kfbh.hard:                          130 ; 0x001: 0x82

kfbh.type:                           22 ; 0x002: KFBTYP_VOLUMEDIR

...

kfvvde.entry.incarn:                  1 ; 0x024: A=1 NUMM=0x0

kfvvde.entry.hash:                    0 ; 0x028: 0x00000000

kfvvde.entry.refer.number:   4294967295 ; 0x02c: 0xffffffff

kfvvde.entry.refer.incarn:            0 ; 0x030: A=0 NUMM=0x0

kfvvde.volnm:                 ACFS_VOL1 ; 0x034: length=9

kfvvde.usage:                           ; 0x054: length=0

kfvvde.dgname:                          ; 0x074: length=0

kfvvde.clname:                          ; 0x094: length=0

kfvvde.mountpath:                       ; 0x0b4: length=0

kfvvde.drlinit:                       0 ; 0x4b5: 0x00

kfvvde.pad1:                          0 ; 0x4b6: 0x0000

kfvvde.volfnum.number:              257 ; 0x4b8: 0x00000101

kfvvde.volfnum.incarn:        771971291 ; 0x4bc: 0x2e0358db

kfvvde.drlfnum.number:              256 ; 0x4c0: 0x00000100

kfvvde.drlfnum.incarn:        771971289 ; 0x4c4: 0x2e0358d9

kfvvde.volnum:                        1 ; 0x4c8: 0x0001

kfvvde.avddgnum:                    159 ; 0x4ca: 0x009f

kfvvde.extentsz:                      8 ; 0x4cc: 0x00000008

kfvvde.volstate:                      2 ; 0x4d0: D=0 C=1 R=0

...


$ kfed read /dev/oracleasm/disks/ASMDISK5 aun=53 blkn=2 | more

kfbh.endian:                          1 ; 0x000: 0x01

kfbh.hard:                          130 ; 0x001: 0x82

kfbh.type:                           22 ; 0x002: KFBTYP_VOLUMEDIR

...

kfvvde.entry.incarn:                  1 ; 0x024: A=1 NUMM=0x0

kfvvde.entry.hash:                    0 ; 0x028: 0x00000000

kfvvde.entry.refer.number:   4294967295 ; 0x02c: 0xffffffff

kfvvde.entry.refer.incarn:            0 ; 0x030: A=0 NUMM=0x0

kfvvde.volnm:                 ACFS_VOL2 ; 0x034: length=9

kfvvde.usage:                           ; 0x054: length=0

kfvvde.dgname:                          ; 0x074: length=0

kfvvde.clname:                          ; 0x094: length=0

kfvvde.mountpath:                       ; 0x0b4: length=0

kfvvde.drlinit:                       0 ; 0x4b5: 0x00

kfvvde.pad1:                          0 ; 0x4b6: 0x0000

kfvvde.volfnum.number:              259 ; 0x4b8: 0x00000103

kfvvde.volfnum.incarn:        771971303 ; 0x4bc: 0x2e0358e7

kfvvde.drlfnum.number:              258 ; 0x4c0: 0x00000102

kfvvde.drlfnum.incarn:        771971301 ; 0x4c4: 0x2e0358e5

kfvvde.volnum:                        2 ; 0x4c8: 0x0002

kfvvde.avddgnum:                    159 ; 0x4ca: 0x009f

kfvvde.extentsz:                      8 ; 0x4cc: 0x00000008

kfvvde.volstate:                      2 ; 0x4d0: D=0 C=1 R=0

...

ASM元信息7号文件block 1包含的是第一个逻辑卷的信息(kfvvde.volnm: ACFS_VOL1),并且有两个文件关联到这个逻辑卷。

· DRL脏数据记录区域文件(kfvvde.drlfnum.number: 256)

· 逻辑卷文件(kfvvde.volfnum.number: 257)

block 2包含第二个逻辑卷的信息(kfvvde.volnm: ACFS_VOL2),并且有两个文件关联到这个逻辑卷。

· DRL脏数据记录区域文件(kfvvde.drlfnum.number: 258)

· 逻辑卷文件(kfvvde.volfnum.number: 259)

这些都是特殊文件,所以不会显示在asmcmd ls命令的输出和v$asm_alias视图中。但是,你可以到v$asm_file中找到他们。

SQL> SELECT file_number "File #", bytes/1024/1024 "Size (MB)", type

FROM v$asm_file

WHERE group_number=2;


    File #  Size (MB) TYPE

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

       256         17 ASMVDRL

       257       2048 ASMVOL

       258         17 ASMVDRL

       259       2048 ASMVOL

Create ASM cluster file system

这时,可以在逻辑卷设备上创建ASM集群文件系统(ACFS)。

# /sbin/mkfs -t acfs /dev/asm/acfs_vol1-159

mkfs.acfs: version                   = 11.2.0.3.0

mkfs.acfs: on-disk version           = 39.0

mkfs.acfs: volume                    = /dev/asm/acfs_vol1-159

mkfs.acfs: volume size               = 2147483648

mkfs.acfs: Format complete.


# mkdir /acfs1


# mount -t acfs /dev/asm/acfs_vol1-159 /acfs1


# mount

/dev/mapper/VolGroup00-LogVol00 on / type ext3 (rw)

...

oracleasmfs on /dev/oracleasm type oracleasmfs (rw)

/dev/asm/acfs_vol1-159 on /acfs1 type acfs (rw)


$ asmcmd volinfo -G ACFS ACFS_VOL1

Diskgroup Name: ACFS


 Volume Name: ACFS_VOL1

 Volume Device: /dev/asm/acfs_vol1-159

 State: ENABLED

 Size (MB): 2048

 Resize Unit (MB): 32

 Redundancy: MIRROR

 Stripe Columns: 4

 Stripe Width (K): 128

 Usage: ACFS

 Mountpath: /acfs1


$

这时候再看看逻辑卷目录中是否包含挂载目录:

$ kfed read /dev/oracleasm/disks/ASMDISK6 aun=53 blkn=1 | grep mountpath

kfvvde.mountpath:                /acfs1 ; 0x0b4: length=6

确实如此。

Conclusion

一个磁盘组中可以配置一个或多个ASM动态逻辑卷设备。ASM集群文件系统通过ADVM接口构建于ASM磁盘组之上。ADVM跟数据库一样,也是ASM的一个客户端。

有两种与ADVM逻辑卷相关的文件类型:

· ASMVOL:逻辑卷文件,作为逻辑卷存储设备的容器

· ASMVDRL:包含脏数据记录区域信息的文件。恢复镜像数据时会用到此文件。


本文来自云栖社区合作伙伴“DBGEEK”

目录
相关文章
|
8月前
|
Oracle 关系型数据库
oracle asm 磁盘显示offline
oracle asm 磁盘显示offline
377 2
|
3月前
|
存储 Oracle 关系型数据库
数据库数据恢复—Oracle ASM磁盘组故障数据恢复案例
Oracle数据库数据恢复环境&故障: Oracle ASM磁盘组由4块磁盘组成。Oracle ASM磁盘组掉线 ,ASM实例不能mount。 Oracle数据库故障分析&恢复方案: 数据库数据恢复工程师对组成ASM磁盘组的磁盘进行分析。对ASM元数据进行分析发现ASM存储元数据损坏,导致磁盘组无法挂载。
|
8月前
|
SQL Oracle 关系型数据库
实时计算 Flink版产品使用合集之使用JDBC方式读取Oracle的number类型时,通过什么方式进行映射
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
186 0
实时计算 Flink版产品使用合集之使用JDBC方式读取Oracle的number类型时,通过什么方式进行映射
|
8月前
|
存储 Oracle 关系型数据库
【数据库数据恢复】Oracle数据库ASM磁盘组掉线的数据恢复案例
oracle数据库ASM磁盘组掉线,ASM实例不能挂载。数据库管理员尝试修复数据库,但是没有成功。
【数据库数据恢复】Oracle数据库ASM磁盘组掉线的数据恢复案例
|
Oracle 关系型数据库 数据库
在Flink CDC中,使用Oracle 11g数据库的NUMBER类型作为主键
在Flink CDC中,使用Oracle 11g数据库的NUMBER类型作为主键
146 1
|
SQL Oracle 关系型数据库
Oracle ASM磁盘和磁盘组的常用SQL语句
Oracle ASM磁盘和磁盘组的常用SQL语句
298 0
|
文字识别 Oracle NoSQL
oracle 11g 单机asm配置
oracle 11g 单机asm配置
689 0
|
Oracle 关系型数据库
❤️Oracle ASM加磁盘及剔盘操作❤️
❤️Oracle ASM加磁盘及剔盘操作❤️
359 0
|
存储 机器学习/深度学习 Oracle
Oracle 11gR2 ASM存储日常管理手册
Oracle 11gR2 ASM存储日常管理手册 目 录1 文档简介 31.1 编写目的 31.2 适用范围 31.3 名词解释 31.4 格式约定 42 配置多链路和LUN 42.
1159 0
|
Oracle 关系型数据库
oracle Grid 是如何找到voteidks和asm spfile.
oracle Grid 是如何找到voteidks和asm spfile.
1553 0

推荐镜像

更多