如何安全扩展磁盘分区?一个自动化脚本帮你搞定!
nanshan 2025-04-26 19:51 11 浏览 0 评论
如何安全扩展磁盘分区?一个自动化脚本帮你搞定!
在日常的系统管理和运维工作中,磁盘分区的扩展是一个常见的需求。无论是物理磁盘还是虚拟磁盘,随着数据量的增长,我们经常需要调整分区大小以应对存储需求的变化。然而,手动操作分区扩展不仅繁琐,还容易出错。今天,我们将介绍一个基于Bash脚本的自动化工具,帮助你安全、高效地扩展磁盘的最后一个分区。
1. 脚本功能概述
这个脚本的主要功能是自动扩展磁盘的最后一个分区,支持物理磁盘和虚拟磁盘(如QEMU格式的磁盘映像)。以下是脚本的核心功能:
- 自动检测磁盘类型:支持物理磁盘和虚拟磁盘的识别。
- 依赖检查与安装:自动检测并安装必要的工具(如qemu-img、parted等)。
- 分区扩展:自动识别最后一个分区,并将其扩展到磁盘的末尾。
- 文件系统扩展:支持常见的文件系统(如ext2/ext3/ext4)的扩展。
- 清理操作:在脚本退出时自动卸载挂载点并断开虚拟磁盘连接,确保系统状态干净。
2. 脚本的核心逻辑
2.1 依赖安装
脚本首先会检查系统是否安装了必要的工具,如qemu-img、qemu-nbd和parted。如果缺少这些工具,脚本会自动尝试安装它们。
install_dependencies() {
local required=("qemu-img" "qemu-nbd" "partprobe")
local missing=()
for cmd in "${required[@]}"; do
if ! command -v "$cmd" >/dev/null 2>&1; then
missing+=("$cmd")
fi
done
if [ ${#missing[@]} -eq 0 ]; then
return 0
fi
echo "检测到缺少依赖命令: ${missing[*]},尝试自动安装..."
sudo apt-get update -qq
sudo apt-get install -y -qq qemu-utils parted >/dev/null
}
2.2 磁盘类型检测
脚本会根据输入的磁盘路径判断是物理磁盘还是虚拟磁盘。如果是虚拟磁盘,脚本会通过NBD(Network Block Device)将其挂载到系统中。
check_disk_format() {
local disk_path="$1"
if [ -b "$disk_path" ]; then
IS_VIRTUAL=false
DISK_DEVICE="$disk_path"
return 0
fi
if qemu-img info "$disk_path" >/dev/null 2>&1; then
IS_VIRTUAL=true
DISK_DEVICE="$NBD_DEVICE"
return 0
fi
echo "错误:无法识别的磁盘格式或设备。"
exit 1
}
2.3 分区扩展
脚本会自动识别磁盘的最后一个分区,并将其扩展到磁盘的末尾。扩展完成后,脚本会根据文件系统类型(如ext4)自动调整文件系统大小。
expand_last_partition() {
local device="$1"
local last_part
local fs_type
local part_num
local disk_size_sectors
local end_sector
echo -n "确认要扩展最后一个分区到磁盘末尾吗?(Yes/No) "
read -r answer
if [ "$answer" != "Yes" ]; then
echo "操作已取消"
exit 0
fi
last_part=$(get_last_partition "$device")
if [ -z "$last_part" ]; then
echo "错误:未找到有效分区"
exit 1
fi
last_part="/dev/${last_part}"
fs_type=$(get_fs_type "$last_part")
echo "检测到最后一个分区 $last_part 的文件系统类型为: $fs_type"
part_num=$(echo "$last_part" | grep -o '[0-9]*#39;)
if [ -z "$part_num" ]; then
echo "错误:无法获取分区号"
exit 1
fi
disk_size_sectors=$(sudo blockdev --getsz "$device")
end_sector=$((disk_size_sectors - 1))
sudo parted -s "$device" unit s resizepart "$part_num" "100%"
handle_error $? "调整分区大小失败"
sudo partprobe "$device"
handle_error $? "刷新分区表失败"
case $fs_type in
ext4|ext3|ext2)
echo "检查并扩展文件系统..."
sudo e2fsck -f -y "$last_part"
handle_error $? "文件系统检查失败"
sudo resize2fs "$last_part"
handle_error $? "文件系统扩展失败"
;;
*)
echo "错误:不支持的文件系统类型 $fs_type"
exit 1
;;
esac
}
2.4 清理操作
脚本在退出时会自动执行清理操作,包括卸载挂载点和断开虚拟磁盘连接,确保系统状态干净。
cleanup() {
local exit_code=$?
echo "执行清理操作..."
for mount_point in "${MOUNT_POINTS[@]}"; do
if [ -d "$mount_point" ]; then
sudo umount "$mount_point" 2>/dev/null
rmdir "$mount_point" 2>/dev/null
fi
done
if $IS_VIRTUAL && [ -e "$NBD_DEVICE" ]; then
sudo qemu-nbd -d "$NBD_DEVICE" 2>/dev/null
fi
exit $exit_code
}
3. 如何使用这个脚本?
3.1 下载脚本
你可以将脚本保存为一个文件,例如expand_disk.sh,并赋予执行权限:
chmod +x expand_disk.sh
3.2 执行脚本
对于物理磁盘,直接指定磁盘设备路径:
sudo ./expand_disk.sh /dev/sdX
对于虚拟磁盘,指定磁盘映像文件路径:
sudo ./expand_disk.sh /path/to/disk.img
3.3 确认操作
脚本会提示你确认是否要扩展最后一个分区。输入Yes后,脚本会自动完成分区扩展和文件系统调整。
4. 总结
这个脚本通过自动化的方式,简化了磁盘分区扩展的操作流程,特别适合需要频繁调整磁盘分区的系统管理员和运维人员。无论是物理磁盘还是虚拟磁盘,脚本都能安全、高效地完成任务。如果你有类似的需求,不妨试试这个脚本,相信它会为你节省大量时间和精力。
相关推荐
- 详细了解ICMP协议(icmp协议的工作原理)
-
最近跟大家分享了一些网络故障排查的命令,今天给大家分享一下,这些命令背后的协议(ICMP)以及原理,只有了解了原理,我们才能更好的用好这些命令什么是ICMP协议Internet控制报文协议ICMP(I...
- Firewalld防火墙与ICMP攻击(防火墙policy)
-
提到ICMP大家应该都很熟悉,可能有人会说:不就是ping吗?但是说到ICMP攻击以及相关防御措施可能就有的人不是非常清楚了。ICMP的概念要想理解ICMP攻击以及防范我们还得从ICMP的概念说起,...
- 不可错过!5张图带你搞懂容器网络原理
-
使用容器总是感觉像使用魔法一样。对于那些理解底层原理的人来说容器很好用,但是对于不理解的人来说就是个噩梦。很幸运的是,我们已经研究容器技术很久了,甚至成功揭秘容器只是隔离并受限的Linux进程,运...
- Iptables防火墙详细介绍(iptables防火墙的原理)
-
一:Linux防火墙基础:Linux防火墙体系主要工作在网络层,针对TCP/IP数据包实施过滤和限制,属于典型的包过滤防火墙(也称网络层防火墙);Linux防火墙体系基于内核编码实现,具有非常稳定的...
- 盘点几个实现VLAN间路由的好方法!
-
在真实的网络中,常常需要跨VLAN通信。许多网络工作者通常选择一些方法来实现不同VLAN中的主机之间的相互访问,如单臂路由。然而,由于单臂路由技术的一些限制,如带宽和转发效率,这种技术是很少使用。三层...
- iptables使用详解(iptables入门)
-
前言最近买了一个VPS,并在上面搭了DOCKER,然后再DOCKER中安装Mysql。但只要将网络端口映射到宿主机上,那么外部网络就可以直接访问该数据。属实吓人。为此,我们需要使用防火墙。说到防火墙,...
- 网络安全-Kali系统hping3及netwox的使用
-
Kali-linux系统自身集成Scapy、hping3、netwox等工具,用于渗透测试及网络攻击ScapyScapy是一个Python程序,Scapy是一个功能强大的交互式数据包操作程序,能够发送...
- 网络工具中的瑞士军刀:Ping和Tracert
-
引言:Ping命令是一种存在于Windows、Unix和Linux系统下的一种命令。往往常用于测试分析判断网络问题所在,ping命令使用ICMP协议,该协议是TCP/IP协议簇的一个子协议,用于在IP...
- 如何确定一个网站是否支持IPv6?(如何判断一个网站)
-
IPv6是互联网协议(IP)的第六版,是互联网工程任务组(IETF)设计的用于替代IPv4的下一代IP协议。为什么国家大力推进互联网协议第六版(IPv6)规模部署?IPv6是为了解决IPv4存在的地址...
- 西门子Profinet故障诊断入门-4(西门子profinet模块)
-
Ping指令如何使用1.概述在做PROFINETIO通讯调试时经常遇到PROFINETIO通讯不通的情况,诊断时可以利用多种诊断工具和方法,这里介绍一下Ping指令的使用方法,利用"pi...
- Linux 网络设备 - Bridge & Veth Pair
-
我们继续介绍Linux中常见的网络设备,今天主要讲的是LinuxBridge和VethPair,理解清楚这两种设备对后续理解容器化网络会比较有帮助。1.vethpair两端互通我们先...
- Ip地址、子网掩码、网关三者如何协调工作你真的理解了吗?
-
首先我们来看看以下这两个地址是否可以相互通信呢?初步一看,貌似可以通信,但是再细看,发现两者的掩码完全不同,故而肯定不能通信了?然而并非如此,如果对两者的通信有更深刻的认识,相信就会发现他们到底能否相...
- 一文精通虚拟端口通道vPC,精品文章,爱了
-
今天给大家带来的是虚拟端口通道相关的技术:简介传统数据中心使用生成树来防止第2层环路,这已经使用了多年,但确实有局限性,为了防止环路,生成树会阻止一些链路并保持其他链路处于活动状态,如下所示,阻塞...
- 5张图诠释了容器网络(容器中的网络模式及特点)
-
使用容器总是感觉像使用魔法一样。对于那些理解底层原理的人来说容器很好用,但是对于不理解的人来说就是个噩梦。很幸运的是,我们已经研究容器技术很久了,甚至成功揭秘容器只是隔离并受限的Linux进程,...
- 抓包结果显示Destination unreachable(port unreachable)怎么排查
-
当Wireshark抓包结果显示Destinationunreachable(Portunreachable)时,表示目标主机的指定端口没有服务监听或无法响应请求。以下是详细的排查步骤和...
你 发表评论:
欢迎- 一周热门
-
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
[常用工具] OpenCV_contrib库在windows下编译使用指南
-
Ubuntu系统Daphne + Nginx + supervisor部署Django项目
-
WindowsServer2022|配置NTP服务器的命令
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
WIN11 安装配置 linux 子系统 Ubuntu 图形界面 桌面系统
-
解决Linux终端中“-bash: nano: command not found”问题
-
NBA 2K25虚拟内存不足/爆内存/内存占用100% 一文速解
-
Linux 中的文件描述符是什么?(linux 打开文件表 文件描述符)
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)