shell脚本案例:RAC多路径-配置ASM磁盘设备权限

使用场景

在RAC多路径配置完成后,需要更改ASM磁盘设备的权限。这个步骤主要分为获取ASM逻辑设备的dm_uuid、配置/etc/udev/rules.d/99-oracle-asmdevices.rules文件、重新加载udev策略并激活策略。这个过程手动去做耗时耗力易出错,所以针对这个情况专门写了个脚本。

Linux版本

脚本代码

bash 复制代码
#!/bin/bash
RED='\033[0;31m'
GREEN='\033[0;32m'
NOCOLOR='\033[0m'


#配置前的asm设备权限
echo "配置前的asm设备权限"
printf "$RED%s %s\n" "`ls -lsa /dev/dm*`"
echo "                            "


#组的创建
echo -e  "\e[32m************************ \e[0m"
echo -e  "\e[32m组信息\e[0m"
echo -e  "\e[32m************************ \e[0m"

group=(oinstall dba oper asmadmin asmdba asmoper)
for i in "${group[@]}"
do
grep "^$i" /etc/group >& /dev/null
  if [ $? != 0 ];
         then
                 if [ $i = "oinstall" ];
                        then  groupadd -g 5001 oinstall; echo "oinstal组已添加"
                 elif [ $i = "dba" ];
                        then groupadd -g 5002 dba; echo "dba组已添加"
                 elif [ $i = "oper" ];
                        then groupadd -g 5003 oper; echo "oper组已添加"
                 elif [ $i = "asmadmin" ];
                        then groupadd -g 5004 asmadmin; echo "asmadmin组已添加"
                 elif [ $i = "asmoper" ];
                        then groupadd -g 5005 asmoper; echo "asmoper组已添加"
                 elif [ $i = "asmdba" ];
                        then groupadd -g 5006 asmdba; echo "asmdba组已添加"
                 fi
          else
              echo "$i组已存在"
        fi
done

#用户的创建
echo -e  "\e[32m************************ \e[0m"
echo -e  "\e[32m用户信息\e[0m"
echo -e  "\e[32m************************ \e[0m"



user=(grid oracle)
for i in "${user[@]}"
do
  grep "^$i" /etc/passwd >& /dev/null
  if [ $? != 0 ];
    then
            if [ $i = grid ]
                  then useradd -u 6002 -g oinstall -G asmadmin,asmdba,asmoper,oper,dba grid ;  echo grid | passwd --stdin grid ; echo "grid用户已添加"
                elif  [ $i = oracle ]
                  then useradd -u 6001 -g oinstall -G dba,asmdba,oper oracle; echo oracle | passwd --stdin oracle; echo "oracle用户已添加"
                fi
        else
                echo "$i用户已存在"
  fi
done

#提前清空规则配置文件
echo '' > /etc/udev/rules.d/99-oracle-asmdevices.rules


#配置asm设备规则文件
for i in `dmsetup ls |grep asm |awk '{print $1}'`
do
   for v in `udevadm info --query=all --name=/dev/mapper/$i |grep -i dm_uuid |awk -F"=" '{print $2}'`
   do
    echo KERNEL==\"dm-*\",ENV{DM_UUID}==\"$v\",OWNER=\"grid\",GROUP=\"asmadmin\",MODE=\"0060\" >> /etc/udev/rules.d/temp.rules
   done
done

#清除文件中的空白行
awk NF /etc/udev/rules.d/temp.rules > /etc/udev/rules.d/99-oracle-asmdevices.rules

#删除临时文件
rm -rf /etc/udev/rules.d/temp.rules

#重载激活规则文件
echo "                            "
echo -e  "\e[32m重载配置文件\e[0m"
/sbin/udevadm control --reload-rules
echo "                            "
echo -e  "\e[32m激活配置文件\e[0m"
/sbin/udevadm trigger --type=devices --action=change
echo "                            "

sleep 5
#配置后的设备权限
echo "配置后的设备权限"
printf "$GREEN%s %s\n" "`ls -lsa /dev/dm*`"
printf "$NOCOLOR%s %s\n" "*************任务完成**************"

执行效果

相关推荐
takashi_void11 分钟前
如何在本地部署大语言模型(Windows,Mac,Linux)三系统教程
linux·人工智能·windows·macos·语言模型·nlp
大聪明-PLUS34 分钟前
QEMU:如何组织与 I2C 设备的透明交互
linux·嵌入式·arm·smarc
sulikey1 小时前
【Linux权限机制深入理解】为何没有目录写权限仍能修改文件权限?
linux·运维·笔记·ubuntu·centos
ytttr8731 小时前
C# 仿QQ聊天功能实现 (SQL Server数据库)
数据库·oracle·c#
liu****1 小时前
8.list的模拟实现
linux·数据结构·c++·算法·list
biubiubiu07061 小时前
VPS SSH密钥登录配置指南:告别密码,拥抱安全
linux
dingdingfish2 小时前
关于Oracle RAC和ADG的学习资料
oracle·database·adg·rac·ha·dr·maa
人生苦短,菜的抠脚2 小时前
Linux 内核IIO sensor驱动
linux·驱动开发
jz_ddk3 小时前
[LVGL] 从0开始,学LVGL:进阶应用与项目实战(上)
linux·信息可视化·嵌入式·gui·lvgl·界面设计
望获linux3 小时前
【实时Linux实战系列】Linux 内核的实时组调度(Real-Time Group Scheduling)
java·linux·服务器·前端·数据库·人工智能·深度学习