磁盘分盘脚本分享

芒果4个月前技术文章121

磁盘分区脚本
名称:mg_fdisk.sh
#!/bin/bash
if [ "$#" -ne 1 ]; then
  echo "请传入磁盘参数"
  exit 1
fi
disk=$1
# 检查磁盘是否存在
if [ ! -b "$disk" ]; then
  echo "磁盘 $disk 不存在"
  exit 1
fi
# 计算磁盘总空间
disk_size=$(fdisk -l $disk | grep "Disk $disk" | awk '{print $5}')
if [ -z "$disk_size" ]; then
  echo "无法获取磁盘空间"
  exit 1
fi
# 删除已有分区(如果存在)
echo "d
w
" | fdisk $disk
# 创建新分区
echo "n
p
1
w
" | fdisk $disk
# 格式化分区
partition="${disk}1"
mkfs.xfs $partition
# 输出结果
echo "磁盘 $disk 分区完成,总空间:$disk_size"
请确保在执行脚本时具备足够的权限,并按以下方式传递磁盘参数进行调用:
./mg_fdisk /dev/sdX
其中,/dev/sdX 是您要进行分区操作的磁盘路径。请替换为您实际使用的磁盘路径。
在执行脚本后,它将删除磁盘上的所有分区并创建一个新的分区。随后,该分区将被格式化为ext4文件系统。最后,脚本将输出磁盘的总空间。
请务必谨慎操作,并确保备份重要数据。
这个脚本可以配合for循环一起用
for i in $(sed 's/[0-9]//g' /opt/disk.txt);do echo $i;/opt/mg_fdisk.sh /dev/$i;done
disk.txt例子
sda1
sbb1
sdc1
sdd1
完成后是这个样哦

搞完之后blkid看一下 如果存在格式化有问题的 可以强制格式化下
mount -f /dev/sdX

磁盘挂载脚本
脚本名称:mg_mount.sh
#!/bin/bash
disk_file="disk.txt"  # 存储分区磁盘列表的文件名
mount_file="mount.txt"  # 存储挂载路径列表的文件名
# 检查文件是否存在
if [ ! -f "$disk_file" ] || [ ! -f "$mount_file" ]; then
  echo "文件不存在"
  exit 1
fi
# 逐行读取分区磁盘和挂载路径
while IFS= read -r disk && IFS= read -r mount <&3; do
  # 挂载分区
  sudo mount "$disk" "$mount"
  if [ "$?" -eq 0 ]; then
    echo "已成功挂载分区 $disk 到路径 $mount"
  else
    echo "挂载分区 $disk 到路径 $mount 失败"
  fi
done < "$disk_file" 3< "$mount_file"
脚本会逐行读取disk_file和mount_file的内容,并分别将其存储到disk和mount变量中,在循环中使用这些变量进行挂载操作。
以下是disk和mount文件的例子
disk.txt
sda1
sbb1
sdc1
sdd1
mount.txt
/data/hadoop/hdfs/data1
/data/hadoop/hdfs/data2
/data/hadoop/hdfs/data3
/data/hadoop/hdfs/data4
完成是这个样子:


通过一个文件来循环读取磁盘名称,并获取UUID和挂载目录写入/etc/fstab
脚本名称:mg_fstab.sh
#!/bin/bash
# 定义磁盘列表文件名
disk_file="/opt/disk.txt"
# 检查文件是否存在
if [ ! -f "$disk_file" ]; then
  echo "文件不存在"
  exit 1
fi
# 逐行读取磁盘列表文件
while IFS= read -r disk_name; do
  # 忽略空白行和注释行(以#开头)
  if [[ -z "$disk_name" || "$disk_name" == \#* ]]; then
    continue
  fi
  # 获取磁盘分区UUID和挂载目录
  uuid=$(blkid -o value -s UUID /dev/"$disk_name")
  mount_dir=$(grep "/dev/$disk_name" /proc/mounts | awk '{print $2}')
  # 检查挂载目录是否存在,不存在则创建
  if [ -z "$mount_dir" ]; then
    mount_dir="/mnt/$disk_name"
    mkdir -p "$mount_dir"
  fi
  # 将分区信息写入/etc/fstab
  echo "UUID=$uuid $mount_dir xfs defaults 0 2" >> /etc/fstab
  echo "UUID=$uuid $mount_dir xfs defaults 0 2 写入成功"
done < "$disk_file"
以下是disk文件的例子
disk.txt
sda1
sbb1
sdc1
sdd1
完成图

Ps如果是想自己传
#!/bin/bash
# 定义磁盘名称
disk_name="sdb1"
# 获取磁盘分区UUID和挂载目录
uuid=$(blkid -o value -s UUID /dev/"$disk_name")
mount_dir=$(grep "/dev/$disk_name" /proc/mounts | awk '{print $2}')
# 将分区信息写入/etc/fstab
  echo "UUID=$uuid $mount_dir xfs defaults 0 2" >> /etc/fstab
  echo "UUID=$uuid $mount_dir xfs defaults 0 2 写入成功"


相关文章

CPU--平均负载

1、原理概述平均负载是指单位时间内,系统处于可运行状态和不可中断状态的平均进程数,也就是平均活跃进程数,它和 CPU 使用率并没有直接关系。   * ...

ranger对接metastore

ranger对接metastore

前提:本文前提是基于集群中已经安装部署了ranger组件、hive组件的情况下,增加ranger metastore插件的对接。安装部署1、ranger metastore插件编译插件下载 https...

Gartner权威报告解读|应用可观测性列为2023年重要战略技术趋势!

Gartner于今日发布企业机构在2023年需要探索的十大战略技术趋势。Gartner杰出研究副总裁Frances Karamouzis表示:“为了在经济动荡时期增加企业机构的盈利,首席信息官和IT高...

hive创建hbase映射表

hive创建hbase映射表

hbase创建表,导入数据/opt/app/hbase-2.1.0/bin/hbase shell查看已有表,创建新表,查看表结构listcreate 'student', 'info', 'scor...

ElasticSearch开启xpack

ElasticSearch开启xpack

ES开启xpack1、生成ca证书(用户名和密码不用设置,一路回车,生成证书文件elastic-stack-ca.p12,生成kibana证书的时候也需要该ca证书)/opt/dtstack/es-6...

trino容器对接ldap(二)

trino容器对接ldap(二)

前提:本文前提是在trino容器已经对接上hive组件,并且ldap已经部署完成的基础上进行的对接。前提文章见:helm安装部署trino对接hive(一)安装部署1、设置证书因为不确定是在哪台机器中...

发表评论    

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