使用udev配置asm

广大8个月前技术文章325

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


相关文章

GitLab Agent Server (KAS)

GitLab Agent Server (KAS)

安装KAS参考资料独立部署的gitlab开启KAS独立部署的gitlab安装kas比较简单,首先编辑gitlab的配置文件/etc/gitlab/gitlab.rb# 取消相关注释 ##! Enab...

MongoDB的索引(二)

四、Case Insesitive索引1、语法db.collection.createIndex(  { "key" : 1 }, { collation: {locale : <local...

emr部署hive并适配达梦数据库

emr部署hive并适配达梦数据库

一、达梦 用户、数据库初始化1、创建hive的元数据库create tablespace hive_meta datafile '/dm8/data/DAMENG/hive_meta.dbf' siz...

EasyMR之Yarn资源队列管理

EasyMR之Yarn资源队列管理

设想一下,你现在所在的公司有一套线上的hadoop集群。A部门经常做一些定时的BI报表,B部门则经常使用一些软件做一些临时需求。那么他们肯定会遇到同时提交任务的场景,这个时候到底如何分配资源满足这两个...

CDH实操--修改集群主机名

CDH实操--修改集群主机名

1、停止集群2、停止cmsystemctl stop cloudera-scm-serversystemctl stop cloudera-scm-agnet3、修改服务器主机名修改下列配置文件下的主...

Flink sql 集成hive metastore-测试

Flink sql 集成hive metastore-测试

FQA1、如何不使用catalog命令,默认进入hive catalog在sql-client-defaults.yaml中添加以下配置2、如何使用mysql使用./bin/sql-client.sh...

发表评论    

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