在增加 EBS 卷的大小后,您必须使用特定于文件系统的命令来将文件系统扩展到较大大小。一旦卷进入 optimizing
状态,您即可调整文件系统的大小。
重要
在扩展包含有用数据的文件系统之前,最佳实践是创建卷的快照(如果您需要回滚您的更改)。有关更多信息,请参阅 创建 Amazon EBS 快照。如果您的 Linux AMI 使用 MBR 分区方案,您的引导卷大小限制为最高 2 TiB。有关更多信息,请参阅 针对 Linux 卷的要求和针对 EBS 卷的大小和配置的限制。
在 Linux 上扩展文件系统的过程如下:
- 您的 EBS 卷可能有一个包含文件系统和数据的分区。增加卷的大小不会增加分区的大小。在调整大小后的卷上扩展文件系统之前,请检查卷是否具有必须扩展到卷的新大小的分区。
- 可使用特定于文件系统的命令将每个文件系统调整为新的卷容量。
有关扩展 Windows 文件系统的信息,请参阅 Amazon EC2 用户指南(适用于 Windows 实例) 中的调整卷大小后扩展 Windows 文件系统。
以下示例将引导您完成扩展 Linux 文件系统的过程。关于此处所示的文件系统和分区方案以外的其他文件系统和分区方案,请参阅相关文件系统和分区方案的文档以获取说明。
注意
如果在 Amazon EBS 卷上使用逻辑卷,则必须使用逻辑卷管理器 (LVM) 来扩展逻辑卷。有关如何执行此操作的说明,请参阅如何在整个 EBS 卷上创建 LVM 逻辑卷?中的扩展逻辑卷部分。 AWS 知识中心文章。
示例
1. 示例:扩展 NVMe EBS 卷的文件系统
对于此示例,假设您有一个基于 Nitro 系统构建的实例,例如 M5 实例。您将引导卷的大小从 8 GB 调整为 16 GB,并将一个附加卷的大小从 8 GB 调整为 30 GB。按照以下过程扩展调整大小后的卷的文件系统。
扩展 NVMe EBS 卷的文件系统
- 连接到您的实例。
- 要验证每个卷的文件系统,请使用 df -hT 命令。
1 | [ec2-user ~]$ df -hT |
以下是一个实例的示例输出,该实例具有带 XFS 文件系统的引导卷和带 XFS 文件系统的附加卷。命名约定 /dev/nvme[0-26]n1
指示卷作为 NVMe 块储存设备公开。
1 | [ec2-user ~]$ df -hT |
3.要检查卷是否具有必须扩展的分区,请使用lsblk命令显示有关附加到实例的 NVMe 块储存设备的信息。
1 | [ec2-user ~]$ lsblk |
此示例输出显示以下内容:
- 根卷
/dev/nvme0n1
具有一个分区/dev/nvme0n1p1
。当根卷的大小反映新大小 16 GB 时,分区的大小会反映原始大小 8 GB 并且必须先进行扩展,然后才能扩展文件系统。 - 卷
/dev/nvme1n1
没有分区。卷的大小反映新大小 30 GB。
- 根卷
4.对于有分区的卷,例如上一步中显示的根卷,请使用 growpart 命令扩展分区。请注意,设备名称和分区编号之间有空格。
1 | [ec2-user ~]$ sudo growpart /dev/nvme0n1 1 |
5.(可选)要验证分区是否反映增大后的卷大小,可再次使用 lsblk 命令。
1 | [ec2-user ~]$ lsblk |
6.要验证每个卷的文件系统的大小,可使用 df -h 命令。在此示例输出中,两个文件系统均反映 8 GB 的原始卷大小。
1 | [ec2-user ~]$ df -h |
7.要扩展每个卷上的文件系统,请对文件系统使用正确的命令,如下所示:
- [XFS 文件系统] 要扩展每个卷上的文件系统,使用 xfs_growfs 命令。在此示例中,
/
和/data
是 df -h 的输出中显示的卷挂载点。
1 | [ec2-user ~]$ sudo xfs_growfs -d / |
如果尚未安装 XFS 工具,可以按如下方式安装。
1 | [ec2-user ~]$ sudo yum install xfsprogs |
- [ext4 文件系统] 要扩展每个卷上的文件系统,使用 resize2fs 命令。
1 | [ec2-user ~]$ sudo resize2fs /dev/nvme0n1p1 |
- [其他文件系统] 要扩展每个卷上的文件系统,请参阅文件系统的文档以获取说明。
8.(可选)要验证每个文件系统是否反映增大后的卷大小,可再次使用 df -h 命令。
1 | [ec2-user ~]$ df -h |
2. 示例:扩展 EBS 卷的文件系统
在本示例中,假设您将某个实例(例如 T2 实例)的引导卷的大小从 8 GB 调整为 16 GB,并将一个附加卷的大小从 8 GB 调整为 30 GB。按照以下过程扩展调整大小后的卷的文件系统。
扩展 EBS 卷的文件系统
- 连接到您的实例。
- 要验证每个卷使用的文件系统,请使用 df -hT 命令。
1 | [ec2-user ~]$ df -hT |
以下是一个实例的示例输出,该实例具有带 ext4 文件系统的引导卷和带 XFS 文件系统的附加卷。
1 | [ec2-user ~]$ df -hT |
3.要检查卷是否具有必须扩展的分区,请使用 lsblk 命令显示有关附加到实例的块储存设备的信息。
1 | [ec2-user ~]$ lsblk |
此示例输出显示以下内容:
- 根卷
/dev/xvda
具有一个分区/dev/xvda1
。当卷的大小为 16 GB 时,分区的大小仍为 8 GB 且必须进行扩展。 - 卷
/dev/xvdf
具有一个分区/dev/xvdf1
。当卷的大小为 30G 时,分区的大小仍为 8 GB 且必须进行扩展。
4.对于有分区的卷,例如上一步中显示的卷,请使用 growpart 命令扩展分区。请注意,设备名称和分区编号之间有空格。
1 | [ec2-user ~]$ sudo growpart /dev/xvda 1 |
5.(可选)要验证分区是否反映增大后的卷大小,可再次使用 lsblk 命令。
1 | [ec2-user ~]$ lsblk |
6.要验证每个卷的文件系统的大小,可使用 df -h 命令。在此示例输出中,两个文件系统均反映 8 GB 的原始卷大小。
1 | [ec2-user ~]$ df -h |
7.要扩展每个卷上的文件系统,请对文件系统使用正确的命令,如下所示:
- [XFS 卷] 要扩展每个卷上的文件系统,使用 xfs_growfs 命令。在此示例中,
/
和/data
是 df -h 的输出中显示的卷挂载点。
1 | [ec2-user ~]$ sudo xfs_growfs -d / |
如果尚未安装 XFS 工具,可以按如下方式安装。
1 | [ec2-user ~]$ sudo yum install xfsprogs |
- [ext4 卷] 要扩展每个卷上的文件系统,使用 resize2fs 命令。
1 | [ec2-user ~]$ sudo resize2fs /dev/xvda1 |
- [其他文件系统] 要扩展每个卷上的文件系统,请参阅文件系统的文档以获取说明。
8.(可选)要验证每个文件系统是否反映增大后的卷大小,可再次使用 df -h 命令。
1 | [ec2-user ~]$ df -h |
3. 报错
1.执行xfs_growfs时报错如下:
1 | [ec2-user ~]$ sudo xfs_growfs -d /data |
解决方法:
1 | [ec2-user ~]$ sudo resize2fs /dev/nvme1n1p1 |
参考:
https://docs.aws.amazon.com/zh_cn/AWSEC2/latest/UserGuide/recognize-expanded-volume-linux.html