百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

如何安全扩展磁盘分区?一个自动化脚本帮你搞定!

nanshan 2025-04-26 19:51 11 浏览 0 评论

如何安全扩展磁盘分区?一个自动化脚本帮你搞定!

在日常的系统管理和运维工作中,磁盘分区的扩展是一个常见的需求。无论是物理磁盘还是虚拟磁盘,随着数据量的增长,我们经常需要调整分区大小以应对存储需求的变化。然而,手动操作分区扩展不仅繁琐,还容易出错。今天,我们将介绍一个基于Bash脚本的自动化工具,帮助你安全、高效地扩展磁盘的最后一个分区。

1. 脚本功能概述

这个脚本的主要功能是自动扩展磁盘的最后一个分区,支持物理磁盘和虚拟磁盘(如QEMU格式的磁盘映像)。以下是脚本的核心功能:

  • 自动检测磁盘类型:支持物理磁盘和虚拟磁盘的识别。
  • 依赖检查与安装:自动检测并安装必要的工具(如qemu-imgparted等)。
  • 分区扩展:自动识别最后一个分区,并将其扩展到磁盘的末尾。
  • 文件系统扩展:支持常见的文件系统(如ext2/ext3/ext4)的扩展。
  • 清理操作:在脚本退出时自动卸载挂载点并断开虚拟磁盘连接,确保系统状态干净。

2. 脚本的核心逻辑

2.1 依赖安装

脚本首先会检查系统是否安装了必要的工具,如qemu-imgqemu-nbdparted。如果缺少这些工具,脚本会自动尝试安装它们。

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)时,表示目标主机的指定端口没有服务监听或无法响应请求。以下是详细的排查步骤和...

取消回复欢迎 发表评论: