新加磁盘初始化脚本

跳转:优化(2022-4-14)

vim initDB.sh

#!/bin/bash
# auther by wangxp EXCLUDE_LIST='2,11'
EXCLUDE_DISK=sda
VG_NAME=vg0 function check {
if test ! $? -eq 0
then
echo "Error!"
exit 1
fi
}
lsblk |grep -v sda
#生成磁盘数组1
VDA_NUM=`lsblk -d -e $EXCLUDE_LIST -p|grep -v $EXCLUDE_DISK|grep -v 'NAME'|wc -l`
if test $VDA_NUM -ge 1;then
echo "-------------- New hard disk detected ---------------------"
for(( i=0; i< ${VDA_NUM} ; i++ ))
do
vda_name=`lsblk -d -e $EXCLUDE_LIST -p|grep -v $EXCLUDE_DISK|grep -v 'NAME'|awk "NR==($i+1)"|awk '{print $1}'`
vda_names[$i]=${vda_name}
done
else
exit 1
fi
#设置选择操作磁盘 VDA_NAME 磁盘名
PS3="Select an unmounted hard disk: "
select VDA_NAME in ${vda_names[@]}
do
if test -z $VDA_NAME
then
echo "Input error!"
exit 1
fi
break
done
#设置挂载点数量
read -p "Input the number of mount points: " POINT_NUM
while true;do
if test -z $POINT_NUM
then
echo "ERROR,input is null"
echo -n "Input the number of mount points: "
read POINT_NUM
else
break
fi
done if test $POINT_NUM -ge 1
then
LV_MAX_SIZE=`lsblk -d -e $EXCLUDE_LIST -p| grep $VDA_NAME|awk '{print $4}'`
LV_FREE_SIZE=${LV_MAX_SIZE%G*}
for (( i=0;i<${POINT_NUM};i++ ))
do
j=$[$i+1]
#设置挂载目录名
read -p "[$j].Input name of ${j}th_mount(default u0$j): " MOUNT_NAME
if test -z $MOUNT_NAME;then
MOUNT_NAME="u0$j"
fi
mount_names[$i]=$MOUNT_NAME
#设置最后一个lv剩余空间大小
echo "Set mount point /${mount_names[$i]}"
if test $[$POINT_NUM-$j] -eq 0
then
echo "Set /${mount_names[$i]} all free size is ${LV_FREE_SIZE}G"
LV_SIZE=$LV_FREE_SIZE
else
#规范空间大小
read -p "Input size of ${mount_names[$i]}(free size ${LV_FREE_SIZE}G): " LV_SIZE
while true;do
if test -z $LV_SIZE
then
echo "ERROR,input is null"
echo -n "Input size of ${mount_names[$i]}(free size ${LV_FREE_SIZE}G): "
read LV_SIZE
elif test $LV_SIZE -ge $LV_FREE_SIZE
then
echo "ERROR,input size greater than or equal to ${LV_FREE_SIZE}G"
echo -n "Input size of ${mount_names[$i]}(free size ${LV_FREE_SIZE}G): "
read LV_SIZE
elif test $LV_SIZE -le 0
then
echo "ERROR,input size less than or equal to 0G"
echo -n "Input size of ${mount_names[$i]}(free size ${LV_FREE_SIZE}G): "
read LV_SIZE
else
break
fi
done
LV_FREE_SIZE=$[$LV_FREE_SIZE-$LV_SIZE]
fi
lv_sizes[$i]=$LV_SIZE
lv_names[$i]=lv${j}
done
else
echo "Input illegal"
fi echo '-----------------'
echo VDA_NAME=$VDA_NAME
echo VG_NAME=$VG_NAME
for (( i=0;i<${POINT_NUM};i++ ))
do
echo "mount point=/${mount_names[$i]} size=${lv_sizes[$i]}G"
done
echo '-----------------'
read -p "Confirm configuration(yes/no)?" INPUT
while true;do
case $INPUT in
y|yes)
#创建物理卷
pvcreate $VDA_NAME
check
#创建逻辑卷组
vgcreate $VG_NAME $VDA_NAME
check
#创建逻辑卷
for (( i=0;i<${POINT_NUM};i++ ))
do
j=$[$i+1]
if test $[$POINT_NUM-$j] -eq 0
then
lvcreate -l +100%free -n "lv${lv_names[$i]}" $VG_NAME
check
else
lvcreate -L ${lv_sizes[$i]}G -n "lv${lv_names[$i]}" $VG_NAME
check
fi
#创建挂载点
mkdir "/${mount_names[$i]}"
check
#格式化逻辑卷
mkfs -t xfs "/dev/$VG_NAME/lv${lv_names[$i]}"
check
#添加fstab开机启动
fstab_lv=`cat /etc/fstab|grep "/dev/mapper/$VG_NAME-lv${lv_names[$i]}"`
if test -z $fstab_lv
then
echo "/dev/mapper/$VG_NAME-lv${lv_names[$i]} /${mount_names[$i]} xfs defaults 0 0" >> /etc/fstab
check
fi
done
#重新加载fstab文件中的内容
echo "mount all point......"
mount -a
lsblk
break
;;
n|no)
break
;;
*)
echo "Input ERROR"
echo -n "Confirm configuration(yes/no)?"
read INPUT
;;
esac
done

优化

  • 识别T级别以上磁盘
  • 排除已经使用的pv
  • 判断是否存在目录

vim initDB.sh

#!/bin/bash
# auther by wangxp function check {
if test ! $? -eq 0
then
echo "Error!"
exit 1
fi
}
#lsblk |grep -v sda
#生成磁盘数组
pv_used_num=`pvs|grep -v PV|wc -l`
for (( i=0; i<$pv_used_num; i++))
do
pv_used_name=`pvs|egrep -o /dev/[[:alpha:]]{3}|awk "NR==($i+1)"`
pv_useds_names[i]=$pv_used_name
done
pv_num=`lsblk -ldp|grep -v sr|grep -v fd|grep -v 'NAME'|wc -l`
for(( i=0; i< ${pv_num} ; i++ ))
do
pv_name=`lsblk -ldp|grep -v sr|grep -v fd|grep -v 'NAME'|awk "NR==($i+1)"|awk '{print $1}'`
pv_names[$i]=${pv_name}
done
#去除已经存在的pv
for (( i=0; i<${pv_num}; i++ ))
do
for (( j=0; j<${pv_used_num}; j++ ))
do
if test "${pv_names[$i]}" == "${pv_useds_names[$j]}";then
unset pv_names[$i]
break
fi
done
done #设置选择操作磁盘 pv_name 磁盘名
PS3="Select an unmounted hard disk: "
select pv_name in ${pv_names[@]}
do
if test -z $pv_name
then
echo "Input error!"
exit 1
fi
break
done #生成了逻辑卷组数组
vg_num=`vgs|grep -v 'VG'|awk '{print $1}'|wc -l`
for(( i=0; i<$vg_num; i++))
do
vg_names[$i]=`vgs|grep -v 'VG'|awk '{print $1}'|awk "NR==$i+1"`
done
#设置vg_name卷组名
for (( j=0; j<$vg_num; j++))
do
VG_NAME="vg$j"
for (( i=0; i<$vg_num; i++))
do
if test "$vg_name" == "${vg_names[$i]}";then
j=$[$j+1]
break
fi
done
done #设置挂载点数量
read -p "Input the number of mount points: " POINT_NUM
while true;do
if test -z $POINT_NUM
then
echo "ERROR,input is null"
echo -n "Input the number of mount points: "
read POINT_NUM
else
break
fi
done if test $POINT_NUM -ge 1
then
LV_MAX_SIZE_BYTE=`lsblk -bdp| grep $pv_name|awk '{print $4}'`
LV_MAX_SIZE=$[${LV_MAX_SIZE_BYTE}/1024/1024/1024]
LV_FREE_SIZE=$LV_MAX_SIZE
for (( i=0;i<${POINT_NUM};i++ ))
do
j=$[$i+1]
#设置挂载目录名
read -p "[$j].Input name of ${j}th_mount(default u0$j): " MOUNT_NAME
if test -z $MOUNT_NAME;then
MOUNT_NAME="u0$j"
fi
if test -d "/${MOUNT_NAME}";then
echo "$MOUNT_NAME is exist!"
exit 1
fi
mount_names[$i]=$MOUNT_NAME
#设置最后一个lv剩余空间大小
echo "Set mount point /${mount_names[$i]}"
if test $[$POINT_NUM-$j] -eq 0
then
echo "Set /${mount_names[$i]} all free size is ${LV_FREE_SIZE}G"
LV_SIZE=$LV_FREE_SIZE
else
#规范空间大小
read -p "Input size of ${mount_names[$i]}(free size ${LV_FREE_SIZE}G): " LV_SIZE
while true;do
if test -z $LV_SIZE
then
echo "ERROR,input is null"
echo -n "Input size of ${mount_names[$i]}(free size ${LV_FREE_SIZE}G): "
read LV_SIZE
elif test $LV_SIZE -ge $LV_FREE_SIZE
then
echo "ERROR,input size greater than or equal to ${LV_FREE_SIZE}G"
echo -n "Input size of ${mount_names[$i]}(free size ${LV_FREE_SIZE}G): "
read LV_SIZE
elif test $LV_SIZE -le 0
then
echo "ERROR,input size less than or equal to 0G"
echo -n "Input size of ${mount_names[$i]}(free size ${LV_FREE_SIZE}G): "
read LV_SIZE
else
break
fi
done
LV_FREE_SIZE=$[$LV_FREE_SIZE-$LV_SIZE]
fi
lv_sizes[$i]=$LV_SIZE
lv_names[$i]=lv${j}
done
else
echo "Input illegal"
fi
echo '-----------------'
echo pv_name=$pv_name
echo VG_NAME=$VG_NAME
for (( i=0;i<${POINT_NUM};i++ ))
do
echo "mount point=/${mount_names[$i]} size=${lv_sizes[$i]}G"
done
echo '-----------------'
read -p "Confirm configuration(yes/no)?" INPUT
while true;do
case $INPUT in
y|yes)
#创建物理卷
pvcreate $pv_name
check
#创建逻辑卷组
vgcreate $VG_NAME $pv_name
check
#创建逻辑卷
for (( i=0;i<${POINT_NUM};i++ ))
do
j=$[$i+1]
if test $[$POINT_NUM-$j] -eq 0
then
lvcreate -l +100%free -n "${lv_names[$i]}" $VG_NAME
check
else
lvcreate -L ${lv_sizes[$i]}G -n "${lv_names[$i]}" $VG_NAME
check
fi
#创建挂载点
mkdir "/${mount_names[$i]}"
check
#格式化逻辑卷
mkfs -t xfs "/dev/$VG_NAME/${lv_names[$i]}"
check
#添加fstab开机启动
fstab_lv=`cat /etc/fstab|grep "/dev/mapper/$VG_NAME-${lv_names[$i]}"`
if test -z $fstab_lv
then
echo "/dev/mapper/$VG_NAME-${lv_names[$i]} /${mount_names[$i]} xfs defaults 0 0" >> /etc/fstab
check
fi
done
#重新加载fstab文件中的内容
echo "mount all point......"
mount -a
lsblk
break
;;
n|no)
break
;;
*)
echo "Input ERROR"
echo -n "Confirm configuration(yes/no)?"
read INPUT
;;
esac
done

initDB.sh初始化磁盘脚本centos7的更多相关文章

  1. centos7初始化bashshell脚本

    centos7初始化bashshell脚本 #!/bin/bash if [[ "$(whoami)" != "root" ]]; then echo &quo ...

  2. ActiveX控件的安全初始化和脚本操作 和 数字签名SIGN

    摘要:数字签名SIGN保证控件在下载时候的安全性.如果你的代码已经经过数字签名,即使用户IE的安全设置很高也能下载,安装并登记.但是在页面上初始化,或者用脚本运行这个控件,为了保证安全性,还需要进行M ...

  3. 阿里云ecs初始化磁盘后远程连接不到服务器

    阿里云初始化磁盘后远程连接不到服务器 报错: WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! ... 原因:阿里云ecs第一次链接服务器之后会在本地电 ...

  4. JLink V8初始化exynos4412脚本

    /** ****************************************************************************** * @author    Maox ...

  5. SQL Server 数据库初始化准备脚本

    通常我们在项目部署前都会写一份数据库初始化脚本.由于数据库外键的限制,我们需要按照数据引用顺序添加初始记录,这个整理过程相当麻烦. 因此写了以下脚本,原理是先去掉所有外键,然后执行一次清空,然后添加数 ...

  6. VS C++工程类成员初始化检测脚本

    最近项目中出现由类成员未初始化而进行读写而造成的问题,于是想将项目中所有的为初始化的地方找出来,优化一下代码,维护了这么多年的程序已有百万余行且VS2015还尚未支持检查类成员初始化的方法.,于是想写 ...

  7. CENTOS 6.6初始化SHELL脚本

    时间:2016-02-24 00:30来源:blog.51cto.com 作者:“xxlixin” 博客 举报 点击:1717次 这个脚本是在刚安装完CENTOS6.6后可能需要进行的操作.在学习CE ...

  8. 使用sh运行bash脚本的奇怪问题

    在同一个文件夹下有两个脚本.a.sh和b.sh,脚本内容例如以下: a.sh: echo "test for a" source b.sh b.sh: echo "tes ...

  9. Shell之监控cpu、内存、磁盘脚本

    #!/bin/bash #获取内存情况 mem_total=`free | awk 'NR==2{print $2}'` #获取内存总大小 mem_use=`free | awk 'NR==2{pri ...

  10. source、sh、./执行脚本对变量的影响

    shell脚本中的变量: local一般用于局部变量声明,多在在函数内部使用. shell脚本中定义的变量是global的,其作用域从被定义的地方开始,到shell结束或被显示删除的地方为止. she ...

随机推荐

  1. (Python基础教程之六)Python中的关键字

    Python基础教程 在SublimeEditor中配置Python环境 Python代码中添加注释 Python中的变量的使用 Python中的数据类型 Python中的关键字 Python字符串操 ...

  2. php-fpm常见错误

    1. WARNING: Nothing matches the include pattern '/usr/local/php7/etc/php-fpm.d/*.conf' # cd /usr/loc ...

  3. 移动端NES网页模拟器(2)

    前言 前面的章节已经封装了一个NES的虚拟按钮,这个章节来封装他的方向键. 在一些NES网页网页模拟器中,方向键要么使用按钮模式,要么使用摇杆模式,各有不足.例如按钮模式无法滑动,用户点了半天才知道点 ...

  4. .NET Core 锁(Lock)底层原理浅谈

    CPU原子操作 原子操作,指一段逻辑要么全部成功,要么全部失败.概念上类似数据库事物(Transaction). CPU能够保证单条汇编的原子性,但不保证多条汇编的原子性 那么在这种情况下,那么CPU ...

  5. 搭建一个文件存储服务器minio,实现文件存储

    搭建一个文件存储服务器minio,实现文件存储 Minio是一个开源的.自托管的对象存储服务器,它提供了类似于云存储服务的功能.你可以使用Minio搭建自己的私有云存储解决方案,或者作为公共存储服务的 ...

  6. sde解除锁定

    在sde数据被锁定的情况下,编辑.创建featureclass或者注册版本的时候会报告:Lock request conflicts with an established lock. 方法一:多半情 ...

  7. 前端每日一知之css常用布局单位

    脑图在线链接 本文内容依据[js每日一题]公众号精彩文章总结而来

  8. CVE-2023-31436 数组越界漏洞

    CVE-2023-31436 数组越界漏洞 drawio: CVE-2023-31436.drawio ‍ 漏洞分析 在 qfq_change_class 里面如果用户态没有提供 TCA_QFQ_LM ...

  9. 2000 Star,是时候为我的开源项目更新下功能了

    哈喽啊,我是阿朗,马上就要年末了,已经半年多没有更新文章了.年初定的计划早已经忘的一干二净.再不捡起来一点东西,就要2025年了. 要写点东西了. 你是一个博客撰写专家,你擅长开发领域,你喜欢使用通俗 ...

  10. 【转载】Spring Cloud Gateway限流详解

    https://www.imooc.com/article/290828/ Spring Cloud Gateway限流详解 2019.08.11 12:56 7257浏览   Spring Clou ...