阿里云服务器linux系统如何原地扩容磁盘?

简介: 您可以按以下步骤完成扩容操作:在控制台上扩容数据盘的磁盘空间。登录实例扩容文件系统。前提条件实例处于 运行中 (Running) 或 已停止(Stopped) 状态。数据盘的状态为 待挂载 或 使用中。

您可以按以下步骤完成扩容操作:

  1. 在控制台上扩容数据盘的磁盘空间。

  2. 登录实例扩容文件系统。

前提条件

  • 实例处于 运行中 (Running) 或 已停止(Stopped) 状态。

  • 数据盘的状态为 待挂载 或 使用中。

  • 数据盘已做分区。

  • 建议在扩容数据盘之前手动创建快照,以备份数据。

注意事项

  • 扩容这种数据盘需要在控制台上重启实例后才能使扩容后的容量生效,而重启实例会停止实例,中断您的业务,所以请您谨慎操作。

  • 包年包月实例如果做过 续费降配 操作,当前计费周期的剩余时间内,实例上的包年包月云盘不支持扩容磁盘操作。

  • 如果数据盘正在创建快照,则不允许执行扩容数据盘的操作。

  • 磁盘扩容功能只能扩容数据盘,不能扩容系统盘或本地盘(本地 SSD 盘等)。

步骤 1. 在控制台上扩容数据盘的磁盘空间

按以下步骤在控制台上扩容数据盘的磁盘空间:

  1. 登录 阿里云服务器ECS管理控制台。

  2. 在左侧导航栏里,选择 存储>云盘。

         

    说明 如果您需要扩容的数据盘已经挂载在某个实例上,您可以单击实例,找到相应实例后,进入实例详情页,并单击本实例磁盘。

  3. 选择地域。

  4. 找到需要扩容的磁盘,并在 操作 列中,选择 更多>磁盘扩容。

  5. 在 磁盘扩容 页面上,设置 扩容后容量,在本示例中为30 GiB。扩容后容量只能比当前容量大。

  6. 待页面上显示费用信息后,单击 确定扩容。

         

    说明 扩容成功后,磁盘列表里即显示扩容后的容量。但是,如果您的数据盘已经挂载到实例上,只有在控制台上 重启实例 后,登录实例才能看到新的磁盘空间容量。

在控制台上扩容数据盘的磁盘空间后,

  • 如果数据盘已经挂载到实例上,您必须 登录实例扩容文件系统。

  • 如果数据盘未挂载到实例上,您必须先挂载数据盘,再根据数据盘的实际情况执行不同的操作:

    • 如果这是一个未格式化的数据盘,您必须格式化数据盘。

    • 如果这个数据盘之前已经格式化并分区,您必须 登录实例扩容文件系统。

步骤 2. 登录实例扩容文件系统

在ECS控制台上完成磁盘扩容后,磁盘每个分区的文件系统并未扩容。您需要登录实例扩容文件系统。

在本示例中,假设数据盘挂载在一台Linux实例上,实例的操作系统为CentOS 7.3 64位,未扩容前的数据盘只有一个主分区(/dev/vdb1,ext4文件系统),文件系统的挂载点为/resizetest,文件系统扩容完成后,数据盘仍然只有一个主分区。

  1. 远程连接实例。

  2. 运行 umount 命令卸载主分区。

       

    umount /dev/vdb1

         

         

    说明 使用        df -h 查看是否卸载成功,如果看不到 /dev/vdb1 的信息表示卸载成功。以下为示例输出结果。

       

    [root@iXXXXXX ~]# df -h
    Filesystem Size Used Avail Use% Mounted on
    /dev/vda1 40G 1.5G 36G 4% /
    devtmpfs 487M 0 487M 0% /dev
    tmpfs 497M 0 497M 0% /dev/shm
    tmpfs 497M 312K 496M 1% /run
    tmpfs 497M 0 497M 0% /sys/fs/cgroup
    tmpfs 100M 0 100M 0% /run/user/0

         

  3. 使用 fdisk 命令删除原来的分区并创建新分区:

         

    说明 如果您使用        parted 工具操作分区,不能与        fdisk 交叉使用,否则会导致分区的起始扇区不一致。

    1. 运行命令 fdisk -l 罗列分区信息并记录扩容前数据盘的最终容量、起始扇区(First sector)位置。

    2. 运行命令 fdisk [数据盘设备名] 进入 fdisk 界面。本示例中,命令为 fdisk /dev/vdb

    3. 输入d并按回车键,删除原来的分区。

             

      说明 删除分区不会造成数据盘内数据的丢失。

    4. 输入n并按回车键,开始创建新的分区。

    5. 输入p并按回车键,选择创建主分区。因为创建的是一个单分区数据盘,所以只需要创建主分区。

             

      说明 如果要创建4个以上的分区,您应该创建至少一个扩展分区,即选择          e

    6. 输入分区编号并按回车键。因为这里仅创建一个分区,所以输入1

    7. 输入第一个可用的扇区编号:为了保证数据的一致性,First sector需要与原来的分区保持一致。在本示例中,按回车键采用默认值。

             

      说明 如果发现First sector显示的位置和之前记录的不一致,说明之前可能使用          parted 来分区,那么就停止当前的          fdisk 操作,使用 parted 重新操作。

    8. 输入最后一个扇区编号:因为这里仅创建一个分区,所以按回车键采用默认值。

    9. 输入 wq 并按回车键,开始分区。

         

      [root@iXXXXXX ~]# fdisk /dev/vdb
      Welcome to fdisk (util-linux 2.23.2).
      Changes will remain in memory only, until you decide to write them.
      Be careful before using the write command.
      Command (m for help): d
      Selected partition 1
      Partition 1 is deleted
      Command (m for help): n
      Partition type:
      p primary (0 primary, 0 extended, 4 free)
      e extended
      Select (default p):
      Using default response p
      Partition number (1-4, default 1):
      First sector (2048-62914559, default 2048):
      Using default value 2048
      Last sector, +sectors or +size{K,M,G} (2048-62914559, default 62914559):
      Using default value 62914559
      Partition 1 of type Linux and of size 30 GiB is setCommand (m for help): wq
      The partition table has been altered!
      Calling ioctl() to re-read partition table.
      Syncing disks.

           

             

      说明 如果您使用的是          parted 工具,进入          parted 界面后,输入p罗列当前的分区情况。如果有分区,则使用 rm+ 序列号来删除老的分区表,然后使用          unit s 定义起始位置,单位使用扇区个数计量,最后使用          mkpart 命令来创建即可,如下图所示。          
                         
             

  4. 部分操作系统里,修改分区后可能会重新自动挂载文件系统。建议先执行 df -h 重新查看文件系统空间和使用情况。如果文件系统重新被挂载,执行 umount [文件系统名称] 再次卸载文件系统。

  5. 检查文件系统,并变更文件系统大小。

       

    e2fsck -f /dev/vdb1 # 检查文件系统resize2fs /dev/vdb1 # 变更文件系统大小

         

         

    说明        

    以下为示例输出结果。

       

    [root@iXXXXXX ~]# e2fsck -f /dev/vdb1
    e2fsck 1.42.9 (28-Dec-2013)
    Pass 1: Checking inodes, blocks, and sizes
    Pass 2: Checking directory structure
    Pass 3: Checking directory connectivity
    Pass 4: Checking reference counts
    Pass 5: Checking group summary information
    /dev/vdb1: 11/1835008 files (0.0% non-contiguous), 159218/7339776 blocks
    [root@iXXXXXX ~]# resize2fs /dev/vdb1
    resize2fs 1.42.9 (28-Dec-2013)
    Resizing the filesystem on /dev/vdb1 to 7864064 (4k) blocks.
    The filesystem on /dev/vdb1 is now 7864064 blocks long.

         

    • 使用 e2fsck 时,由于系统需要检查并订正文件系统元数据,所以速度较慢、耗时较长,请耐心等待。

    • 正确使用 e2fsck 和 resize2fs 指令,不会造成原有数据丢失。

  6. 将扩容完成的文件系统挂载到原来的挂载点(如本示例中的 /resizetest)。

       

    mount /dev/vdb1 /resizetest

         

  7. 查看文件系统空间和使用情况:运行命令 df -h。如果出现扩容后的文件系统信息,说明挂载成功,可以使用扩容后的文件系统了。

         

    说明 挂载操作完成后,不需要在控制台上重启实例即可开始使用扩容后的文件系统。

    以下为示例输出结果。

       

    [root@iXXXXXX ~]# df -h
    Filesystem Size Used Avail Use% Mounted on
    /dev/vda1 40G 1.5G 36G 4% /
    devtmpfs 487M 0 487M 0% /dev
    tmpfs 497M 0 497M 0% /dev/shm
    tmpfs 497M 312K 496M 1% /run
    tmpfs 497M 0 497M 0% /sys/fs/cgroup
    tmpfs 100M 0 100M 0% /run/user/0/dev/vdb1 30G 44M 28G 1% /resizetest
    
相关实践学习
快速体验PolarDB开源数据库
本实验环境已内置PostgreSQL数据库以及PolarDB开源数据库:PolarDB PostgreSQL版和PolarDB分布式版,支持一键拉起使用,方便各位开发者学习使用。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
205
分享
相关文章
|
26天前
|
Linux系统之whereis命令的基本使用
Linux系统之whereis命令的基本使用
68 24
Linux系统之whereis命令的基本使用
Linux服务器部署docker windows
在当今软件开发中,Docker成为流行的虚拟化技术,支持在Linux服务器上运行Windows容器。流程包括:1) 安装Docker;2) 配置支持Windows容器;3) 获取Windows镜像;4) 运行Windows容器;5) 验证容器状态。通过这些步骤,你可以在Linux环境中顺利部署和管理Windows应用,提高开发和运维效率。
26 1
|
3月前
|
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
294 78
Linux系统查看操作系统版本信息、CPU信息、模块信息
在Linux系统中,常用命令可帮助用户查看操作系统版本、CPU信息和模块信息
148 23
深入解析操作系统控制台:阿里云Alibaba Cloud Linux(Alinux)的运维利器
本文将详细介绍阿里云的Alibaba Cloud Linux操作系统控制台的功能和优势。
106 6
云上体验最佳的服务器操作系统 - Alibaba Cloud Linux | 飞天技术沙龙-CentOS 迁移替换专场
本次方案的主题是云上体验最佳的服务器操作系统 - Alibaba Cloud Linux ,从 Alibaba Cloud Linux 的产生背景、产品优势以及云上用户使用它享受的技术红利等方面详细进行了介绍。同时,通过国内某社交平台、某快递企业、某手机客户大数据业务 3 大案例,成功助力客户实现弹性扩容能力提升、性能提升、降本增效。 1. 背景介绍 2. 产品介绍 3. 案例分享
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
135 13
安装【银河麒麟V10】linux系统--并挂载镜像
安装【银河麒麟V10】linux系统--并挂载镜像
2886 0
卸载、下载、安装mysql(Linux系统centos7)
卸载、下载、安装mysql(Linux系统centos7)
289 0
|
5月前
|
手把手教会你安装Linux系统
手把手教会你安装Linux系统
126 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等