使用udev配置asm

广大2年前技术文章993

环境:centos7    

1、udev介绍

  • udev概念

udev 是 Linux2.6 内核里的一个功能,它替代了原来的 devfs,成为当前 Linux 默认的设备管理工具。udev 以守护进程的形式运行,通过侦听内核发出来的 uevent 来管理 /dev目录下的设备文件。不像之前的设备管理工具,udev 在用户空间 (user space) 运行,而不在内核空间 (kernel space) 运行。

2、udev配置asm步骤

2.1、查看磁盘信息

#查看磁盘信息
fdisk -l
#根据上一步获取磁盘信息进行查看
ls -l /dev/sd*

2.2、获取WWID

WWID是磁盘的一个独一无二的标识,scsi_id命令执行后,只有磁盘、存储盘才可以显示wwid,多路径的存储盘显示的wwid一样,存储盘分区活分区格式化后,存储盘本身的wwid不变

UUID是文件系统的标识,blkid命令执行后,磁盘、本地磁盘分区、存储盘都可以显示uuid,且uuid之间有-横杠,多路径的存储盘显示的uuid一样,存储盘进行分区但是不格式的话,分区没有uuid,存储盘本身的uuid不变,存储盘进行分区且格式的话,分区有uuid,存储盘本身的uuid改变了。

注意:应用服务器上/ets/fstab里面只能使用uuid,不能使用wwid

  • 获取wwid命令和脚本

#命令1:
/usr/lib/udev/scsi_id --whitelisted --replace-whitespace --device=/dev/sd$i(指定磁盘)

#命令2:
/usr/lib/udev/scsi_id -g -u  /dev/sd$i/(指定磁盘)


2.3、编写脚本制作99-oracle-asmdevices.rules内容

  1. 获取KERNEL基本信息命令

#nvme1n1需要换成/sys/block/下具体的磁盘
# udevadm info -a -p /sys/block/nvme1n1
  1. 根据获取的KERNEL信息编写获取wwid的脚本

两个脚本选择一个执行即可。

for i in `cat /proc/partitions | awk {'print $4'} `; 
do
echo "KERNEL==\"$i\", ENV{DEVTYPE}==\"disk\", SUBSYSTEM==\"block\", PROGRAM==\"/usr/lib/udev/scsi_id -g -u -d \$devnode\", RESULT==\"`/usr/lib/udev/scsi_id --whitelisted --replace-whitespace --device=/dev/$i`\", RUN+=\"/bin/sh -c 'mknod /dev/asm-disk$i b \$major \$minor; chown grid:asmadmin /dev/asm-disk$i; chmod 0660 /dev/asm-disk$i'\""
done

该脚本会输出所有盘,选择共享存储盘的规则复制到99-oracle-asmdevices.rules文件中。

2.4、根据脚本内容制作99-oracle-asmdevices.rules

配置udev的规则文件/etc/udev/rules.d/99-oracle-asmdevices.rules(修改磁盘别名为ocrX 和 data 便于后期创建asm 方便认识,也可以不修改)

  • 脚本一输出修改:

该方式RUN中使用mknod命令真实创建udev设备。

[root@rac1 ~]# cat /etc/udev/rules.d/99-oracle-asmdevices.rules

KERNEL=="nvme1n1", ENV{DEVTYPE}=="disk", SUBSYSTEM=="block", PROGRAM=="/usr/lib/udev/scsi_id -g -u -d $devnode", RESULT=="SNVMe_Alibaba_Cloud_Eluf6amt35i4q8l85qffvr", RUN+="/bin/sh -c 'mknod /dev/asm-ocr1 b $major $minor; chown grid:asmadmin /dev/asm-ocr1; chmod 0660 /dev/asm-ocr1'"
KERNEL=="nvme2n1", ENV{DEVTYPE}=="disk", SUBSYSTEM=="block", PROGRAM=="/usr/lib/udev/scsi_id -g -u -d $devnode", RESULT=="SNVMe_Alibaba_Cloud_Eluf6amt35i4q8l85qffvt", RUN+="/bin/sh -c 'mknod /dev/asm-ocr2 b $major $minor; chown grid:asmadmin /dev/asm-ocr2; chmod 0660 /dev/asm-ocr2'"
KERNEL=="nvme3n1", ENV{DEVTYPE}=="disk", SUBSYSTEM=="block", PROGRAM=="/usr/lib/udev/scsi_id -g -u -d $devnode", RESULT=="SNVMe_Alibaba_Cloud_Eluf6amt35i4q8l85qffvs", RUN+="/bin/sh -c 'mknod /dev/asm-ocr3 b $major $minor; chown grid:asmadmin /dev/asm-ocr3; chmod 0660 /dev/asm-ocr3'"
KERNEL=="nvme4n1", ENV{DEVTYPE}=="disk", SUBSYSTEM=="block", PROGRAM=="/usr/lib/udev/scsi_id -g -u -d $devnode", RESULT=="SNVMe_Alibaba_Cloud_Eluf6cdmidni893wbmft4u", RUN+="/bin/sh -c 'mknod /dev/asm-data b $major $minor; chown grid:asmadmin /dev/asm-data; chmod 0660 /dev/asm-data'"



2.5、启动udev

配置完成后启动udev即可

##crntos7命令
[root@linux7 rules.d]# /sbin/udevadm trigger --type=devices --action=change

##centos8命令
/sbin/udevadm control --reload-rules
/sbin/udevadm trigger

##如果修改配置文件后重新加载udev命令(如果还不生效可以重启生效)
/sbin/udevadm control --reload

2.6、配置完成后查看磁盘

[root@rac1 ~]# ll /dev/asm-*

brw-rw---- 1 grid asmadmin 259, 5 Sep  7 21:57 /dev/asm-data

brw-rw---- 1 grid asmadmin 259, 4 Sep  7 21:57 /dev/asm-ocr1

brw-rw---- 1 grid asmadmin 259, 3 Sep  7 21:57 /dev/asm-ocr2

brw-rw---- 1 grid asmadmin 259, 2 Sep  7 21:57 /dev/asm-ocr3


相关文章

MySQL运维实战(3.3) 管理数据库(database)

数据库使用create database语句创建数据库。创建数据库的账号需要有create权限。创建数据库用户拥有create权限才能创建数据库。-- 例子:创建dba用户,拥有创建数据库名...

使用CoreDNS搭建DNS服务器

使用CoreDNS搭建DNS服务器

简介CoreDNS是一个DNS服务器/转发器,用Go编写,可以链接插件。每个插件执行一个 (DNS) 功能。CoreDNS是云原生计算基金会毕业的项目。CoreDNS是一个快速灵活的DNS服务器。这里...

PostgreSQL 锁等待排查

PostgreSQL 锁等待排查

说明在数据库中,常用 锁 和 MVCC 来保障事务的一致性及提高并发性。锁问题的定位和排查也是数据库运维人员必会的技能,本篇文章介绍 PostgreSQL 如何排查定位锁堵塞问题。1. Postgre...

MySQL 评估 ALTER TABLE 进度(5.7)

MySQL 评估 ALTER TABLE 进度(5.7)

一、前言问题:大表里执行 ALTER TABLE 的时候,经常会比较忐忑,会面临 “跑又跑不完 Kill 也不敢 Kill” 的窘境。需求:客户在执行 ALTER TABLE 时也会让我们来评估影响的...

RBAC配置只读用户

一.背景有时候需要给第三方业务访问k8s集群,但是rancher无法实现提取容器内文件的功能。此时需要给第三方直接访问k8s集群的能力,并且进行一定的权限限制二.操作前了解相关配置和要求熟悉linux...

爬坑记录------容器内外网络不通,端口无法访问

爬坑记录------容器内外网络不通,端口无法访问

背景:客户需要一套datahub用于分许sparksql血缘,因此需要基于docker搭建,在搭建过程中遇到一个较坑的问题,这里做以记录搭建完成后查看docker容器已经正常启动查看红框中的内容信息,...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。