扩展数据盘的分区和文件系统(Linux)
操作场景
通过云服务管理控制台扩容成功后,仅扩大了云硬盘的存储容量,因此需要参考本章节操作扩展分区和文件系统。
对于Linux操作系统而言,需要将扩容部分的容量划分至已有分区内,或者为扩容部分的云硬盘分配新的分区。
本文以“CentOS 7.4 64位”操作系统为例,提供MBR分区和GPT分区的操作指导。不同操作系统的操作可能不同,本文仅供参考,具体操作步骤和差异请参考对应操作系统的产品文档。
扩容时请谨慎操作,误操作可能会导致数据丢失或者异常,建议扩容前对数据进行备份,可以使用CBR功能或者快照功能,CBR请参见管理备份云硬盘,快照功能请参见《云硬盘接口参考》。
前提条件
- 已通过管理控制台扩容云硬盘容量,并已挂载至弹性云服务器,请参见扩容“正在使用”状态的云硬盘容量或者扩容“可用”状态的云硬盘容量。
- 已登录弹性云服务器。
- 弹性云服务器请参见《弹性云服务器用户指南》。
- 裸金属服务器请参见《裸金属服务器用户指南》。
约束与限制
- 数据盘不支持扩容到根分区,如果您需要扩容根分区请扩容系统盘。
- 扩展磁盘分区和文件系统时,只能将新增容量扩展至磁盘的尾部分区。
新增MBR分区
数据盘“/dev/vdb”原有容量100GiB,只有一个分区“/dev/vdb1”。将数据盘容量扩大至150GiB,本示例为新增的50GiB分配新的MBR分区“/dev/vdb2”。
- 执行以下命令,查看磁盘的分区信息。
fdisk -l
回显类似如下信息:[root@ecs-test-0001 ~]# fdisk -l Disk /dev/vda: 42.9 GiB, 42949672960 bytes, 83886080 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: dos Disk identifier: 0x000bcb4e Device Boot Start End Blocks Id System /dev/vda1 * 2048 83886079 41942016 83 Linux Disk /dev/vdb: 161.1 GiB, 161061273600 bytes, 314572800 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: dos Disk identifier: 0x38717fc1 Device Boot Start End Blocks Id System /dev/vdb1 2048 209715199 104856576 83 Linux
- 执行以下命令,进入fdisk分区工具。
fdisk 磁盘
命令示例:
fdisk /dev/vdb
回显类似如下信息:[root@ecs-test-0001 ~]# 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):
- 输入“n”,按“Enter”,开始新建分区。
回显类似如下信息:
Command (m for help): n Partition type: p primary (1 primary, 0 extended, 3 free) e extended Select (default p):
表示磁盘有两种分区类型:- “p”表示主分区。
- “e”表示扩展分区。
磁盘使用MBR分区形式,最多可以创建4个主分区,或者3个主分区加1个扩展分区,扩展分区不可以直接使用,需要划分成如果干个逻辑分区才可以使用。
磁盘使用GPT分区形式时,没有主分区、扩展分区以及逻辑分区之分。
- 以创建一个主分区为例,输入“p”,按“Enter”。
回显类似如下信息:
Select (default p): p Partition number (2-4, default 2):
“Partition number”表示主分区编号,可以选择2-4,由于1已被使用,此处从2开始。
- 以分区编号选择“2”为例,输入分区编号“2”,按“Enter”。
回显类似如下信息:
Partition number (2-4, default 2): 2 First sector (209715200-314572799, default 209715200):
“First sector”表示起始磁柱值,可以选择209715200-314572799,默认为209715200。
- 输入新分区的起始磁柱值,以使用默认起始磁柱值为例,按“Enter”。
系统会自动提示分区可用空间的起始磁柱值和截止磁柱值,可以在该区间内自定义,或者使用默认值。起始磁柱值必须小于分区的截止磁柱值。
回显类似如下信息:First sector (209715200-314572799, default 209715200): Using default value 209715200 Last sector, +sectors or +size{K,M,G} (209715200-314572799, default 314572799):
“Last sector”表示截止磁柱值,可以选择209715200-314572799,默认为314572799。
- 输入新分区的截止磁柱值,以使用默认截止磁柱值为例,按“Enter”。
系统会自动提示分区可用空间的起始磁柱值和截止磁柱值,可以在该区间内自定义,或者使用默认值。起始磁柱值必须小于分区的截止磁柱值。
回显类似如下信息:Last sector, +sectors or +size{K,M,G} (209715200-314572799, default 314572799): Using default value 314572799 Partition 2 of type Linux and of size 50 GiB is set Command (m for help):
- 输入“p”,按“Enter”,查看新建分区。
回显类似如下信息:
Command (m for help): p Disk /dev/vdb: 161.1 GiB, 161061273600 bytes, 314572800 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: dos Disk identifier: 0x38717fc1 Device Boot Start End Blocks Id System /dev/vdb1 2048 209715199 104856576 83 Linux /dev/vdb2 209715200 314572799 52428800 83 Linux Command (m for help):
- 输入“w”,按“Enter”,将分区结果写入分区表中。
回显类似如下信息:
Command (m for help): w The partition table has been altered! Calling ioctl() to re-read partition table. WARNING: Re-reading the partition table failed with error 16: Device or resource busy. The kernel still uses the old table. The new table will be used at the next reboot or after you run partprobe(8) or kpartx(8) Syncing disks.
如果之前分区操作有误,请输入“q”,则会退出fdisk分区工具,之前的分区结果将不会被保留。
- 执行以下命令,将新的分区表变更同步至操作系统。
partprobe
- 执行以下命令,为新建分区设置文件系统。
mkfs -t 文件系统 磁盘分区
- ext*文件系统命令示例:
回显类似如下信息:
[root@ecs-test-0001 ~]# mkfs -t ext4 /dev/vdb2 mke2fs 1.42.9 (28-Dec-2013) Filesystem label= OS type: Linux Block size=4096 (log=2) Fragment size=4096 (log=2) Stride=0 blocks, Stripe width=0 blocks 3276800 inodes, 13107200 blocks 655360 blocks (5.00%) reserved for the super user First data block=0 Maximum filesystem blocks=2162163712 400 block groups 32768 blocks per group, 32768 fragments per group 8192 inodes per group Superblock backups stored on blocks: 32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 4096000, 7962624, 11239424 Allocating group tables: done Writing inode tables: done Creating journal (32768 blocks): done Writing superblocks and filesystem accounting information: done
- xfs文件系统命令示例:
回显类似如下信息:
[root@ecs-test-0001 ~]# mkfs -t xfs /dev/vdb2 meta-data=/dev/vdb2 isize=512 agcount=4, agsize=3276800 blks = sectsz=512 attr=2, projid32bit=1 = crc=1 finobt=0, sparse=0 data = bsize=4096 blocks=13107200, imaxpct=25 = sunit=0 swidth=0 blks naming =version2 bsize=4096 ascii-ci=0 ftype=1 log =internal log bsize=4096 blocks=6400, version=2 = sectsz=512 sunit=0 blks, lazy-count=1 realtime =none extsz=4096 blocks=0, rtextents=0
格式化需要等待一段时间,请观察系统运行状态,如果回显中进程提示为done,则表示格式化完成。
- ext*文件系统命令示例:
- (可选)执行以下命令,新建挂载目录。
如果需要挂载至新建目录下,执行该操作。
mkdir 挂载目录
以新建挂载目录“/mnt/test”为例:
mkdir /mnt/test
- 执行以下命令,挂载新建分区。
mount 磁盘分区 挂载目录
以挂载新建分区“/dev/vdb2”至“/mnt/test”为例:
mount /dev/vdb2 /mnt/test
新增加的分区挂载到不为空的目录时,该目录下原本的子目录和文件会被隐藏,所以,建议将新增的分区挂载到空目录或者新建目录。如确实要挂载到不为空的目录,可将该目录下的子目录和文件临时移动到其他目录下,新分区挂载成功后,再将子目录和文件移动回来。
- 执行以下命令,查看挂载结果。
df -TH
回显类似如下信息:[root@ecs-test-0001 ~]# df -TH Filesystem Type Size Used Avail Use% Mounted on /dev/vda1 ext4 43G 1.9G 39G 5% / devtmpfs devtmpfs 2.0G 0 2.0G 0% /dev tmpfs tmpfs 2.0G 0 2.0G 0% /dev/shm tmpfs tmpfs 2.0G 9.1M 2.0G 1% /run tmpfs tmpfs 2.0G 0 2.0G 0% /sys/fs/cgroup tmpfs tmpfs 398M 0 398M 0% /run/user/0 /dev/vdb1 ext4 106G 63M 101G 1% /mnt/sdc /dev/vdb2 ext4 53G 55M 50G 1% /mnt/test
弹性云服务器重启后,挂载会失效。您可以修改“/etc/fstab”文件,将新建磁盘分区设置为开机自动挂载,请参见设置开机自动挂载磁盘分区。
扩大已有MBR分区
扩大已有分区不会删除数据盘上的数据,但是需要通过umount命令先卸载已有分区,因此会影响线上业务运行。
数据盘“/dev/vdb”原有容量150GiB,有两个分区“/dev/vdb1 ”和“/dev/vdb2”。将数据盘容量扩大至230GiB,本示例将新增的80GiB划分至已有的MBR分区内“/dev/vdb2”内。
扩容后的新增存储空间是添加在磁盘末尾的,对具有多个分区的的磁盘扩容时,只支持将新增容量划分至排在末尾的分区。
- 执行以下命令,查看磁盘的分区信息。
fdisk -l
回显类似如下信息:[root@ecs-test-0001 ~]# fdisk -l Disk /dev/vda: 42.9 GiB, 42949672960 bytes, 83886080 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: dos Disk identifier: 0x000bcb4e Device Boot Start End Blocks Id System /dev/vda1 * 2048 83886079 41942016 83 Linux Disk /dev/vdb: 247.0 GiB, 246960619520 bytes, 482344960 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: dos Disk identifier: 0x38717fc1 Device Boot Start End Blocks Id System /dev/vdb1 2048 209715199 104856576 83 Linux /dev/vdb2 209715200 314572799 52428800 83 Linux
记录待扩大分区的起始磁柱值(Start)和截止磁柱值(End),本示例中待扩大分区“/dev/vdb2”的起始磁柱值为209715200,截止磁柱值为314572799。
查看回显中数据盘“/dev/vdb”的容量,扩容的容量是否已经包含在容量总和中。- 如果扩容的容量未在数据盘容量总和中,请参考扩展SCSI数据盘的分区和文件系统(Linux)章节刷新系统内容量。
- 如果扩容的容量已在数据盘容量总和中,请记录待扩大分区的起始和截止磁柱值,这些值在后续重新创建分区时需要使用,记录完成后执行2。
- 执行以下命令,卸载磁盘分区。
umount 磁盘分区
命令示例:
umount /dev/vdb2
- 执行以下命令,进入fdisk分区工具。
fdisk 磁盘
命令示例:
fdisk /dev/vdb
回显类似如下信息:[root@ecs-test-0001 ~]# 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”,按“Enter”,删除磁盘分区。
- 输入分区编号,此处以分区编号选择“2”为例,按“Enter”,删除磁盘分区。
删除分区后,请参考以下操作步骤扩大原有分区,则不会导致数据盘内数据的丢失。
- 输入“n”,按“Enter”,开始新建分区。
回显类似如下信息:
Command (m for help): n Partition type: p primary (1 primary, 0 extended, 3 free) e extended Select (default p):
表示磁盘有两种分区类型:- “p”表示主分区。
- “e”表示扩展分区。
磁盘使用MBR分区形式,最多可以创建4个主分区,或者3个主分区加1个扩展分区,扩展分区不可以直接使用,需要划分成如果干个逻辑分区才可以使用。
磁盘使用GPT分区形式时,没有主分区、扩展分区以及逻辑分区之分。
- 此处分区类型需要与原分区保持一致,以原分区类型是“主分区”为例,输入“p”,按“Enter”,开始重新创建一个主分区。
回显类似如下信息:
Select (default p): p Partition number (2-4, default 2):
“Partition number”表示主分区编号。
- 此处分区编号需要与原分区保持一致,以原分区编号是“2”为例,输入分区编号“2”,按“Enter”。
回显类似如下信息:
Partition number (2-4, default 2): 2 First sector (209715200-482344959, default 209715200):
“First sector”表示起始磁柱值。
以下操作会导致数据丢失:- 选择的起始磁柱值与原分区的不一致。
- 选择的截止磁柱值小于原分区的值。
- 此处必须与原分区保持一致,输入1中记录的初始磁柱值209715200,此处该值也为默认值,按“Enter”。
回显类似如下信息:
First sector (209715200-482344959, default 209715200): Using default value 209715200 Last sector, +sectors or +size{K,M,G} (209715200-482344959, default 482344959):
“Last sector”表示截止磁柱值。
- 此处截止磁柱值应大于等于1中记录的截止磁柱值314572799,以选择默认截止磁柱值482344959为例,按“Enter”。
回显类似如下信息:
Using default value 209715200 Last sector, +sectors or +size{K,M,G} (209715200-482344959, default 482344959): Using default value 482344959 Partition 2 of type Linux and of size 130 GiB is set Command (m for help):
表示分区完成。
- 输入“p”,按“Enter”,查看分区的详细信息。
回显类似如下信息:
Command (mfor help): p Disk /dev/vdb: 247.0 GiB, 246960619520 bytes, 482344960 sectors Units = sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 512 bytes I/O size (minimum/optimal): 512 bytes / 512 bytes Disk label type: dos Disk identifier: 0x38717fc1 Device Boot Start End Blocks Id System /dev/vdb1 2048 209715199 104856576 83 Linux /dev/vdb2 209715200 482344959 136314880 83 Linux Command (m for help):
- 输入“w”,按“Enter”,将分区结果写入分区表中。
回显类似如下信息:
Command (m for help): w The partition table has been altered! Calling ioctl() to re-read partition table. WARNING: Re-reading the partition table failed with error 16: Device or resource busy. The kernel still uses the old table. The new table will be used at the next reboot or after you run partprobe(8) or kpartx(8) Syncing disks.
如果之前分区操作有误,请输入“q”,则会退出fdisk分区工具,之前的分区结果将不会被保留。
- 执行以下命令,将新的分区表变更同步至操作系统。
partprobe
- 根据磁盘的文件系统,分别执行以下操作。
- 如果磁盘文件系统为ext*,请执行以下步骤。
- 执行以下命令,检查磁盘分区文件系统的正确性。
命令示例:
e2fsck -f /dev/vdb2
回显类似如下信息:[root@ecs-test-0001 ~]# e2fsck -f /dev/vdb2 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/vdb2: 11/3276800 files (0.0% non-contiguous), 251790/13107200 blocks
- 执行以下命令,扩展磁盘分区文件系统的大小。
命令示例:
resize2fs /dev/vdb2
回显类似如下信息:[root@ecs-test-0001 ~]# resize2fs /dev/vdb2 resize2fs 1.42.9 (28-Dec-2013) Resizing the filesystem on /dev/vdb2 to 34078720 (4k) blocks. The filesystem on /dev/vdb2 is now 34078720 blocks long.
如果出现报错“open: No such file or directory while opening /dev/vdb1”,则表示您指定的磁盘分区不正确,请使用 “df -TH” 命令查看磁盘分区。
- (可选)执行以下命令,新建挂载目录。
mkdir 挂载目录
以新建挂载目录“/mnt/test”为例:
mkdir /mnt/test
- 执行以下命令,挂载磁盘分区。
以挂载分区“/dev/vdb2”至“/mnt/test”为例:
mount /dev/vdb2 /mnt/test
新增加的分区挂载到不为空的目录时,该目录下原本的子目录和文件会被隐藏,所以,建议将新增的分区挂载到空目录或者新建目录。如确实要挂载到不为空的目录,可将该目录下的子目录和文件临时移动到其他目录下,新分区挂载成功后,再将子目录和文件移动回来。
- 执行以下命令,检查磁盘分区文件系统的正确性。
- 如果磁盘文件系统为xfs,请执行以下步骤。
- (可选)执行以下命令,新建挂载目录。
mkdir 挂载目录
以新建挂载目录“/mnt/test”为例:
mkdir /mnt/test
- 执行以下命令,挂载磁盘分区。
以挂载分区“/dev/vdb2”至“/mnt/test”为例:
mount /dev/vdb2 /mnt/test
新增加的分区挂载到不为空的目录时,该目录下原本的子目录和文件会被隐藏,所以,建议将新增的分区挂载到空目录或者新建目录。如确实要挂载到不为空的目录,可将该目录下的子目录和文件临时移动到其他目录下,新分区挂载成功后,再将子目录和文件移动回来。
- 执行以下命令,扩展磁盘分区文件系统的大小。
命令示例:
sudo xfs_growfs /dev/vdb2
回显类似如下信息:
[root@ecs-test-0001 ~]# sudo xfs_growfs /dev/vdb2 meta-data=/dev/vdb2 isize=512 agcount=4, agsize=3276800 blks = sectsz=512 attr=2, projid32bit=1 = crc=1 finobt=0, spinodes=0 data = bsize=4096 blocks=13107200, imaxpct=25 = sunit=0 swidth=0 blks naming =version2 bsize=4096 ascii-ci=0 ftype=1 log =internal bsize=4096 blocks=6400, version=2 = sectsz=512 sunit=0 blks, lazy-count=1 realtime =none extsz=4096 blocks=0, rtextents=0 data blocks changed from 13107200 to 34078720.
- (可选)执行以下命令,新建挂载目录。
- 如果磁盘文件系统为ext*,请执行以下步骤。
- 执行以下命令,查看挂载结果。
df -TH
回显类似如下信息:[root@ecs-test-0001 ~]# df -TH Filesystem Type Size Used Avail Use% Mounted on /dev/vda1 ext4 43G 1.9G 39G 5% / devtmpfs devtmpfs 2.0G 0 2.0G 0% /dev tmpfs tmpfs 2.0G 0 2.0G 0% /dev/shm tmpfs tmpfs 2.0G 9.1M 2.0G 1% /run tmpfs tmpfs 2.0G 0 2.0G 0% /sys/fs/cgroup tmpfs tmpfs 398M 0 398M 0% /run/user/0 /dev/vdb1 ext4 106G 63M 101G 1% /mnt/sdc /dev/vdb2 ext4 138G 63M 131G 1% /mnt/test
新增GPT分区
数据盘“/dev/vdb”原有容量100GiB,只有一个分区“/dev/vdb1”。将数据盘容量扩大至150GiB,本示例为新增的50GiB分配新的GPT分区“/dev/vdb2”。
- 执行以下命令,查看磁盘的分区信息。
lsblk
回显类似如下信息:[root@ecs-test-0001 ~]# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT vda 253:0 0 40G 0 disk └─vda1 253:1 0 40G 0 part / vdb 253:16 0 150G 0 disk └─vdb1 253:17 0 100G 0 part /mnt/sdc
- 执行以下命令,进入parted分区工具。
parted 磁盘
命令示例:
parted /dev/vdb
回显类似如下信息:[root@ecs-test-0001 ~]# parted /dev/vdb GNU Parted 3.1 Using /dev/vdb Welcome to GNU Parted! Type 'help' to view a list of commands. (parted)
- 输入“unit s”,按“Enter”,设置磁盘的计量单位为磁柱。
- 输入“p”,按“Enter”,查看当前磁盘分区情况。
回显类似如下信息:
(parted) unit s (parted) p Error: The backup GPT table is not at the end of the disk, as it should be. This might mean that another operating system believes the disk is smaller. Fix, by moving the backup to the end (and removing the old backup)? Fix/Ignore/Cancel? Fix Warning: Not all of the space available to /dev/vdb appears to be used, you can fix the GPT to use all of the space (an extra 104857600 blocks) or continue with the current setting? Fix/Ignore? Fix Model: Virtio Block Device (virtblk) Disk /dev/vdb: 314572800s Sector size (logical/physical): 512B/512B Partition Table: gpt Disk Flags: Number Start End Size File system Name Flags 1 2048s 209713151s 209711104s ext4 test (parted)
记录已有分区的截止磁柱值(End),本示例中已有分区“/dev/vdb1”的截止磁柱值为209713151s。- 如果系统出现以下Error,请输入“Fix”。
Error: The backup GPT table is not at the end of the disk, as it should be. This might mean that another operating system believes the disk is smaller. Fix, by moving the backup to the end (and removing the old backup)?
GPT分区表信息存储在磁盘开头,为了减少分区表损坏的风险,同时在磁盘末尾会备份一份。当磁盘容量扩大后,末尾位置也会随之变化,因此需要根据系统提示输入“Fix”,将分区表信息的备份文件挪到新的磁盘末尾位置。
- 如果系统出现以下Warning,请输入“Fix”。
Warning: Not all of the space available to /dev/vdb appears to be used, you can fix the GPT to use all of the space (an extra 104857600 blocks) or continue with the current setting? Fix/Ignore? Fix
根据系统提示输入“Fix”,系统会自动将磁盘扩容部分的容量设置为GPT。
- 如果系统出现以下Error,请输入“Fix”。
- 以为新增容量分配一整个分区为例,执行以下命令,按“Enter”。
mkpart 磁盘分区名称 起始磁柱值 截止磁柱值
命令示例:
mkpart data 209713152s 100%
由于4中,已有分区“dev/vdb1”的截止磁柱值为“209713151s”,因此对于新增分区“dev/vdb2”,起始磁柱值设置为“209713152s”,截止磁柱值设置为“100%”。此处仅供参考,您可以根据业务需要自行规划磁盘分区数量及容量。
回显类似如下信息:(parted) mkpart data 209713152s 100% (parted)
- 输入“p”,按“Enter”,查看新建分区。
回显类似如下信息:
(parted) p Model: Virtio Block Device (virtblk) Disk /dev/vdb: 314572800s Sector size (logical/physical): 512B/512B Partition Table: gpt Disk Flags: Number Start End Size File system Name Flags 1 2048s 209713151s 209711104s ext4 test 2 209713152s 314570751s 104857600s data (parted)
- 执行以下命令,为新建分区设置文件系统。
mkfs -t 文件系统 磁盘分区
- ext*文件系统命令示例:
回显类似如下信息:
[root@ecs-test-0001 ~]# mkfs -t ext4 /dev/vdb2 mke2fs 1.42.9 (28-Dec-2013) Filesystem label= OS type: Linux Block size=4096 (log=2) Fragment size=4096 (log=2) Stride=0 blocks, Stripe width=0 blocks 3276800 inodes, 13107200 blocks 655360 blocks (5.00%) reserved for the super user First data block=0 Maximum filesystem blocks=2162163712 400 block groups 32768 blocks per group, 32768 fragments per group 8192 inodes per group Superblock backups stored on blocks: 32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 4096000, 7962624, 11239424 Allocating group tables: done Writing inode tables: done Creating journal (32768 blocks): done Writing superblocks and filesystem accounting information: done
- xfs文件系统命令示例:
回显类似如下信息:
[root@ecs-test-0001 ~]# mkfs -t xfs /dev/vdb2 meta-data=/dev/vdb2 isize=512 agcount=4, agsize=3276800 blks = sectsz=512 attr=2, projid32bit=1 = crc=1 finobt=0, sparse=0 data = bsize=4096 blocks=13107200, imaxpct=25 = sunit=0 swidth=0 blks naming =version2 bsize=4096 ascii-ci=0 ftype=1 log =internal log bsize=4096 blocks=6400, version=2 = sectsz=512 sunit=0 blks, lazy-count=1 realtime =none extsz=4096 blocks=0, rtextents=0
格式化需要等待一段时间,请观察系统运行状态,如果回显中进程提示为done,则表示格式化完成。
- ext*文件系统命令示例:
- (可选)执行以下命令,新建挂载目录。
如果需要挂载至新建目录下,执行该操作。
mkdir 挂载目录
以新建挂载目录“/mnt/test”为例:
mkdir /mnt/test
- 执行以下命令,挂载新建分区。
mount 磁盘分区 挂载目录
以挂载新建分区“/dev/vdb2”至“/mnt/test”为例:
mount /dev/vdb2 /mnt/test
新增加的分区挂载到不为空的目录时,该目录下原本的子目录和文件会被隐藏,所以,建议将新增的分区挂载到空目录或者新建目录。如确实要挂载到不为空的目录,可将该目录下的子目录和文件临时移动到其他目录下,新分区挂载成功后,再将子目录和文件移动回来。
- 执行以下命令,查看挂载结果。
df -TH
回显类似如下信息:[root@ecs-test-0001 ~]# df -TH Filesystem Type Size Used Avail Use% Mounted on /dev/vda1 ext4 43G 1.9G 39G 5% / devtmpfs devtmpfs 2.0G 0 2.0G 0% /dev tmpfs tmpfs 2.0G 0 2.0G 0% /dev/shm tmpfs tmpfs 2.0G 9.1M 2.0G 1% /run tmpfs tmpfs 2.0G 0 2.0G 0% /sys/fs/cgroup tmpfs tmpfs 398M 0 398M 0% /run/user/0 /dev/vdb1 ext4 106G 63M 101G 1% /mnt/sdc /dev/vdb2 ext4 53G 55M 50G 1% /mnt/test
弹性云服务器重启后,挂载会失效。您可以修改“/etc/fstab”文件,将新建磁盘分区设置为开机自动挂载,请参见设置开机自动挂载磁盘分区。
扩大已有GPT分区
扩大已有分区不会删除数据盘上的数据,但是需要通过umount命令先卸载已有分区,因此会影响线上业务运行。
数据盘“/dev/vdb”原有容量150GiB,有两个分区“/dev/vdb1 ”和“/dev/vdb2”。将数据盘容量扩大至230GiB,本示例将新增的80GiB划分至已有的GPT分区内“/dev/vdb2”内。
扩容后的新增存储空间是添加在磁盘末尾的,对具有多个分区的的磁盘扩容时,只支持将新增容量划分至排在末尾的分区。
- 执行以下命令,查看磁盘的分区信息。
lsblk
回显类似如下信息:[root@ecs-test-0001 ~]# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT vda 253:0 0 40G 0 disk └─vda1 253:1 0 40G 0 part / vdb 253:16 0 230G 0 disk ├─vdb1 253:17 0 100G 0 part /mnt/sdc └─vdb2 253:18 0 50G 0 part /mnt/test
查看回显中磁盘“/dev/vdb”的容量,扩容的容量是否已经包含在容量总和中。- 如果扩容的容量未在磁盘容量总和中,请参考扩展SCSI数据盘的分区和文件系统(Linux)章节刷新系统内容量。
- 如果扩容的容量已在磁盘容量总和中,请执行2。
- 执行以下命令,卸载磁盘分区。
umount 磁盘分区
命令示例:
umount /dev/vdb2
- 执行以下命令,确认磁盘分区的卸载结果。
lsblk
回显类似如下信息:[root@ecs-test-0001 ~]# lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT vda 253:0 0 40G 0 disk └─vda1 253:1 0 40G 0 part / vdb 253:16 0 230G 0 disk ├─vdb1 253:17 0 100G 0 part /mnt/sdc └─vdb2 253:18 0 50G 0 part
- 执行以下命令,进入parted分区工具。
parted 磁盘
命令示例:
parted /dev/vdb
回显类似如下信息:[root@ecs-test-0001 ~]# parted /dev/vdb GNU Parted 3.1 Using /dev/vdb Welcome to GNU Parted! Type 'help' to view a list of commands. (parted)
- 输入“unit s”,按“Enter”,设置磁盘的计量单位为磁柱。
- 输入“p”,按“Enter”,查看当前磁盘分区情况。
回显类似如下信息:
(parted) unit s (parted) p Error: The backup GPT table is not at the end of the disk, as it should be. This might mean that another operating system believes the disk is smaller. Fix, by moving the backup to the end (and removing the old backup)? Fix/Ignore/Cancel? Fix Warning: Not all of the space available to /dev/vdb appears to be used, you can fix the GPT to use all of the space (an extra 167772160 blocks) or continue with the current setting? Fix/Ignore? Fix Model: Virtio Block Device (virtblk) Disk /dev/vdb: 482344960s Sector size (logical/physical): 512B/512B Partition Table: gpt Disk Flags: Number Start End Size File system Name Flags 1 2048s 209713151s 209711104s ext4 test 2 209713152s 314570751s 104857600s ext4 data (parted)
记录待扩大分区“/dev/vdb2”的初始磁柱值(start)和截止磁柱值(End),在后续重新划分分区需要使用。本示例中待扩大分区的的初始磁柱值为209713152s,截止磁柱值为314570751s。- 如果系统出现以下Error,请输入“Fix”。
Error: The backup GPT table is not at the end of the disk, as it should be. This might mean that another operating system believes the disk is smaller. Fix, by moving the backup to the end (and removing the old backup)?
GPT分区表信息存储在磁盘开头,为了减少分区表损坏的风险,同时在磁盘末尾会备份一份。当磁盘容量扩大后,末尾位置也会随之变化,因此需要根据系统提示输入“Fix”,将分区表信息的备份文件挪到新的磁盘末尾位置。
- 如果系统出现以下Warning,请输入“Fix”。
Warning: Not all of the space available to /dev/vdb appears to be used, you can fix the GPT to use all of the space (an extra 104857600 blocks) or continue with the current setting? Fix/Ignore? Fix
根据系统提示输入“Fix”,系统会自动将磁盘扩容部分的容量设置为GPT。
- 如果系统出现以下Error,请输入“Fix”。
- 输入“rm”和分区编号,此处以“2”为例,按“Enter”。
回显类似如下信息:
(parted) rm Partition number? 2 (parted)
- 重新划分分区,执行以下命令,按“Enter”。
mkpart 磁盘分区名称 起始磁柱值 截止磁柱值
命令示例:
mkpart data 209713152s 100%
- 起始起始磁柱值需要和原分区的取值保持一致,输入6中记录的起始磁柱值“209713152s”。
- 截止磁柱值必须大于原分区的取值,即大于6中记录的截止磁柱值“314570751s”,此处以将所有新增容量划分至分区“dev/vdb2”为例,输入100%。
回显类似如下信息:(parted) mkpart data 209713152s 100% (parted)
以下操作会导致数据丢失:- 选择的起始磁柱值与原分区的不一致。
- 选择的截止磁柱值小于原分区的值。
- 输入“p”,按“Enter”,查看分区信息。
回显类似如下信息:
(parted) p Model: Virtio Block Device (virtblk) Disk /dev/vdb: 482344960s Sector size (logical/physical): 512B/512B Partition Table: gpt Disk Flags: Number Start End Size File system Name Flags 1 2048s 209713151s 209711104s ext4 test 2 209713152s 482342911s 272629760s ext4 data (parted)
- 根据磁盘的文件系统,分别执行以下操作。
- 如果磁盘文件系统为ext*,请执行以下步骤。
- 执行以下命令,检查磁盘分区文件系统的正确性。
命令示例:
e2fsck -f /dev/vdb2
回显类似如下信息:[root@ecs-test-0001 ~]# e2fsck -f /dev/vdb2 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/vdb2: 11/3276800 files (0.0% non-contiguous), 251790/13107200 blocks
- 执行以下命令,扩展磁盘分区文件系统的大小。
命令示例:
resize2fs /dev/vdb2
回显类似如下信息:[root@ecs-test-0001 ~]# resize2fs /dev/vdb2 resize2fs 1.42.9 (28-Dec-2013) Resizing the filesystem on /dev/vdb2 to 34078720 (4k) blocks. The filesystem on /dev/vdb2 is now 34078720 blocks long.
如果出现报错“open: No such file or directory while opening /dev/vdb1”,则表示您指定的磁盘分区不正确,请使用 “df -TH” 命令查看磁盘分区。
- (可选)执行以下命令,新建挂载目录。
mkdir 挂载目录
以新建挂载目录“/mnt/test”为例:
mkdir /mnt/test
- 执行以下命令,挂载磁盘分区。
以挂载分区“/dev/vdb2”至“/mnt/test”为例:
mount /dev/vdb2 /mnt/test
新增加的分区挂载到不为空的目录时,该目录下原本的子目录和文件会被隐藏,所以,建议将新增的分区挂载到空目录或者新建目录。如确实要挂载到不为空的目录,可将该目录下的子目录和文件临时移动到其他目录下,新分区挂载成功后,再将子目录和文件移动回来。
- 执行以下命令,检查磁盘分区文件系统的正确性。
- 如果磁盘文件系统为xfs,请执行以下步骤。
- (可选)执行以下命令,新建挂载目录。
mkdir 挂载目录
以新建挂载目录“/mnt/test”为例:
mkdir /mnt/test
- 执行以下命令,挂载磁盘分区。
以挂载分区“/dev/vdb2”至“/mnt/test”为例:
mount /dev/vdb2 /mnt/test
新增加的分区挂载到不为空的目录时,该目录下原本的子目录和文件会被隐藏,所以,建议将新增的分区挂载到空目录或者新建目录。如确实要挂载到不为空的目录,可将该目录下的子目录和文件临时移动到其他目录下,新分区挂载成功后,再将子目录和文件移动回来。
- 执行以下命令,扩展磁盘分区文件系统的大小。
命令示例:
sudo xfs_growfs /dev/vdb2
回显类似如下信息:
[root@ecs-test-0001 ~]# sudo xfs_growfs /dev/vdb2 meta-data=/dev/vdb2 isize=512 agcount=4, agsize=3276800 blks = sectsz=512 attr=2, projid32bit=1 = crc=1 finobt=0, spinodes=0 data = bsize=4096 blocks=13107200, imaxpct=25 = sunit=0 swidth=0 blks naming =version2 bsize=4096 ascii-ci=0 ftype=1 log =internal bsize=4096 blocks=6400, version=2 = sectsz=512 sunit=0 blks, lazy-count=1 realtime =none extsz=4096 blocks=0, rtextents=0 data blocks changed from 13107200 to 34078720.
- (可选)执行以下命令,新建挂载目录。
- 如果磁盘文件系统为ext*,请执行以下步骤。
- 执行以下命令,查看挂载结果。
df -TH
回显类似如下信息:[root@ecs-test-0001 ~]# df -TH Filesystem Type Size Used Avail Use% Mounted on /dev/vda1 ext4 43G 1.9G 39G 5% / devtmpfs devtmpfs 2.0G 0 2.0G 0% /dev tmpfs tmpfs 2.0G 0 2.0G 0% /dev/shm tmpfs tmpfs 2.0G 9.1M 2.0G 1% /run tmpfs tmpfs 2.0G 0 2.0G 0% /sys/fs/cgroup tmpfs tmpfs 398M 0 398M 0% /run/user/0 /dev/vdb1 ext4 106G 63M 101G 1% /mnt/sdc /dev/vdb2 ext4 138G 63M 131G 1% /mnt/test
设置开机自动挂载磁盘分区
您可以通过配置fstab文件,设置弹性云服务器系统启动时自动挂载磁盘分区。已有数据的弹性云服务器也可以进行设置,该操作不会影响现有数据。
本文介绍如何在fstab文件中使用UUID来设置自动挂载磁盘分区。不建议采用在“/etc/fstab”直接指定设备名(比如/dev/vdb1)的方法,因为云中设备的顺序编码在关闭或者开启弹性云服务器过程中可能发生改变,例如/dev/vdb1可能会变成/dev/vdb2,可能会导致弹性云服务器重启后不能正常运行。
UUID(universally unique identifier)是Linux系统为磁盘分区提供的唯一的标识字符串。
- 执行如下命令,查询磁盘分区的UUID。
blkid 磁盘分区
以查询磁盘分区“/dev/vdb1”的UUID为例:
blkid /dev/vdb1
回显类似如下信息:
[root@ecs-test-0001 ~]# blkid /dev/vdb1 /dev/vdb1: UUID="0b3040e2-1367-4abb-841d-ddb0b92693df" TYPE="ext4"
记录下回显中磁盘分区“/dev/vdb1”的UUID,方便后续步骤使用。
- 执行以下命令,使用VI编辑器打开“fstab”文件。
vi /etc/fstab
- 按“i”,进入编辑模式。
- 将光标移至文件末尾,按“Enter”,添加如下内容。
UUID=0b3040e2-1367-4abb-841d-ddb0b92693df /mnt/sdc ext4 defaults 0 2
- 按“ESC”后,输入“:wq”,按“Enter”。
保存设置并退出编辑器。
- 执行以下步骤,验证自动挂载功能。