使用udev配置asm

广大2年前技术文章1322

环境: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


相关文章

stress压测工具

1、stress 概述stress是一个linux的压力测试工具,主要用来模拟系统负载较高时的场景,用于对系统的CPU、IO、内存、负载、磁盘等进行压力测试2、安装yum install -y epe...

 MySQL性能优化(十)in参数列表过长导致的性能问题

MySQL性能优化(十)in参数列表过长导致的性能问题

有时候可能有人会问:where条件中使用in和or有什么区别,哪种写法性能更好?in参数个数有没有限制?下面就是一个由于in参数列表过长导致的性能问题。一个例子当时使用的是mysql 5.6版本SEL...

kubernetes调度和调度器

一、Kubernetes调度Scheduler 是 kubernetes 的调度器,主要的任务是把定义的 pod 分配到集群的节点上。听起来非常简单,但有很多要考虑的问题:公平:如何保证每个节点都能被...

Kafka副本策略

Kafka副本策略

Kafka的高可靠性的保障来源于其健壮的副本(replication)策略。1. 数据同步kafka在0.8版本前没有提供Partition的Replication机制,一旦Broker宕机,其上的所...

MySQL运维实战(3.2) 常见数据库连接失败问题排查

如果数据库连接失败,可以从如下几方面来排查:1、客户端到服务端的网络是否畅通,服务端端口是否能连通。使用ping、telnet等工具探测服务端的端口是否能访问。[root@box3 ~]#&...

trino组件对接hudi(四)

trino组件对接hudi(四)

安装部署本文是基于已经部署了trino组件的环境上,进行的trino和hudi的对接,使trino组件能够正常查询hudi表。1、增加hudi connector配置在trino安装部署下的etc/c...

发表评论    

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