磁盘分盘脚本分享

芒果1年前技术文章576

磁盘分区脚本
名称: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 写入成功"


相关文章

hive 报 找不到或无法加载主类 org.apache.hadoop.mapreduce.v2.app.MRAppMaster

hive 报 找不到或无法加载主类 org.apache.hadoop.mapreduce.v2.app.MRAppMaster

解决办法:关键需要配置两个配置:mapred-site.xml 和 yarn-site.xml下面配置hadoop classpath。先运行shell命令:hadoop classpath添加一个配...

IDC:疫情下,第三方云管理服务市场逆势增长!

IDC:疫情下,第三方云管理服务市场逆势增长!

IDC预测,中国第三方云管理服务在2019年到2023年间将保持54.7%的增长率,2023年市场规模预计达到32.1亿美元。2019年第三方云管理服务市场呈现出如下特点:云管理服务成为众多服务商的战...

使用Sqoop将数据从Hive导入MySQL(一)

使用Sqoop将数据从Hive导入MySQL(一)

使用Sqoop将数据从Hive导入MySQL首先查看csv数据类型创建类似的hive表并导入数据CREATE TABLE data (    province STRING,    code INT,...

EMR-java配置国密SM4加密

EMR-java配置国密SM4加密

首先找到bcprov-jdk15on-1.56.jar这个包<dependency>    <groupId>org.bouncycastle</groupId> ...

HBase使用snappy压缩

HBase使用snappy压缩

安装编译环境依赖yum install -y automake autoconf gcc-c++ cmake libedit libtool openssl-devel ncurses-devel安装...

kubernetes HPA

kubernetes HPA

Horizontal Pod Autoscaling 可以根据 CPU 利用率自动伸缩一个 ReplicaSet、Deployment 或者中的 Pod 数量cat hpa-deploy.yaml a...

发表评论    

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