共计 5892 个字符,预计需要花费 15 分钟才能阅读完成。
导读 | 精简卷是可以创建大于可用磁盘的逻辑卷。使用精简卷,你可以管理可用空间的存储池(称为精简池),可以在应用程序需要时将其分配给任意数量的设备。精简池可以在需要时进行动态扩展,以节省成本。 |
Centos8
下面我们添加一块硬盘。创建物理卷,然后创建卷组:
[ | ]|
Physical volume "/dev/sda" successfully created. | |
[ | ]|
Volume group "vg_thin" successfully created | |
[ | ]|
VG | |
cl 1 2 0 wz--n- <19.00g <2.00g | |
vg_thin 1 0 0 wz--n- <20.00g <20.00g |
上面已经创建好一个新的卷组了,名字为vg_thin
。然后在现有卷组的中创建一个精简池:
[root@localhost ~]# lvcreate -L 1G -T vg_thin/thin_pool | |
Thin pool volume with chunk size 64.00 KiB can address at most 15.81 TiB of data. | |
Logical volume "thin_pool" created.[root@localhost ~]# lvs LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert | |
root cl -wi-ao---- 15.00g | |
swap cl -wi-ao---- 2.00g | |
thin_pool vg_thin twi-a-tz-- 1.00g 0.00 10.94 |
创建精简池之后,我们就可以从精简池中创建精简卷。在本实验中创建四个精简卷,每个精简卷的大小为 200 MB。
[ | ]|
Logical volume "tp_lv_user1" created. | |
[ | ]|
Logical volume "tp_lv_user2" created. | |
[ | ]|
Logical volume "tp_lv_user3" created. | |
[ | ]|
Logical volume "tp_lv_user4" created. |
将上面创建的四个精简卷格式化为 xfs 格式:
[ | ]|
[ | ]|
[ | ]|
[ | ]
创建挂载点,并挂载:
[ | ]|
[ | ]|
[ | ]|
[ | ]|
[ | ]
向这四个目录写入一些文件:
[ | ]|
[ | ]|
[ | ]|
[ | ]
然后运行下面命令查看以下使用空间:
[root@localhost ~]# lvs
我们可以注意到精简池利用率为 41.41%
再创建两个 200 MB 的精简卷。可以发现创建这两个精简卷会超过所设置的精简池的大小,虽然可以创建成功,但这样做会有更大的风险,并提示一些超额的警告。
[root@localhost ~]# lvcreate -V 200M -T vg_thin/thin_pool -n tp_lv_user5 | |
Logical volume "tp_lv_user5" created. | |
[root@localhost ~]# lvcreate -V 200M -T vg_thin/thin_pool -n tp_lv_user6 | |
WARNING: Sum of all thin volume sizes (1.17 GiB) exceeds the size of thin pool vg_thin/thin_pool (1.00 GiB). | |
WARNING: You have not turned on protection against thin pools running out of space. | |
WARNING: Set activation/thin_pool_autoextend_threshold below 100 to trigger automatic extension of thin pools before they get full. | |
Logical volume "tp_lv_user6" created. |
下面我们删掉刚才创建的 tp_lv_user5 和 tp_lv_user6,在 lvm.conf 配置文件中开启超额保护,并重新创建这两个精简卷:
[ | ]|
Logical volume "tp_lv_user5" successfully removed | |
[ | ]|
Logical volume "tp_lv_user6" successfully removed |
编辑 /etc/lvm/lvm.conf
配置文件,将下两个参数的值修改一下:
# 当精简池的使用率超过此百分比时,将自动扩展该池,将其更改为 100 将禁用自动扩展。可接受的最小值是 50。thin_pool_autoextend_threshold = 80 | |
# 通过自动扩展精简池,会增加这个百分比的额外空间。添加到精简池的额外空间量是其当前大小的百分比。thin_pool_autoextend_percent = 20 |
下面创建 tp_lv_user5 和 tp_lv_user6 两个精简卷:
[ | ]|
Logical volume "tp_lv_user5" created. | |
[ | ]|
Logical volume "tp_lv_user6" created. | |
[ | ]|
[ | ]|
[ | ]|
[ | ]|
[ | ]
看一下使用的情况:
下面我们向 /mnt/user5 和 /mnt/user6 填充内容,直到 thin_pool 精简池的使用率超过 80%,我们可以看到精简池的容量扩容了。
[root@localhost ~]# lvs LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert | |
root cl -wi-ao---- 15.00g | |
swap cl -wi-ao---- 2.00g | |
thin_pool vg_thin twi-aotz-- 1.20g 75.94 22.66 | |
tp_lv_user1 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user2 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user3 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user4 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user5 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user6 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 |
可以看到上面,thin_pool 精简池的容量提升了 200M,这就说明当精简池的使用率超过 80% 时,提升 20% 的容量。
扩展精简池时,我们需要遵循两个步骤:
- 1. 扩展精简池的元数据
- 2. 然后再扩展精简池。
要扩展精简池,我们不应该立即继续扩展精简池。首先,通过运行 lvs -a
查看现有元数据使用的大小情况。
[root@localhost ~]# lvs -a | |
LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert | |
root cl -wi-ao---- 15.00g | |
swap cl -wi-ao---- 2.00g | |
[lvol0_pmspare] vg_thin ewi------- 4.00m | |
thin_pool vg_thin twi-aotz-- 1.20g 75.94 22.66 | |
[thin_pool_tdata] vg_thin Twi-ao---- 1.20g | |
[thin_pool_tmeta] vg_thin ewi-ao---- 4.00m | |
tp_lv_user1 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user2 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user3 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user4 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user5 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 | |
tp_lv_user6 vg_thin Vwi-aotz-- 200.00m thin_pool 77.97 |
元数据的当前大小仅为 4 MB。让我们在当前大小的基础上添加 4MB。
[root@localhost ~]# lvextend --poolmetadatasize +4M vg_thin/thin_pool
可以看到 [thin_pool_tmeta]
已经变成 8M 了。
完成扩展元数据后,开始将精简池扩展到所需的大小。将精简池扩容量再添加 1G 容量。
[root@localhost ~]# lvextend -L +1G /dev/vg_thin/thin_pool
现在大小已变成 2.2G 了。
扩展精简卷和扩展精简池类似:
[root@localhost ~]# lvextend -L +200M /dev/vg_thin/tp_lv_user1
要删除精简池,首先需要卸载所有文件系统,然后删除所有精简卷,最后删除精简池。
[ | ]|
[ | ]|
Logical volume "tp_lv_user1" successfully removed | |
Logical volume "tp_lv_user2" successfully removed | |
Logical volume "tp_lv_user3" successfully removed | |
Logical volume "tp_lv_user4" successfully removed | |
Logical volume "tp_lv_user5" successfully removed | |
Logical volume "tp_lv_user6" successfully removed | |
[ | ]|
Logical volume "thin_pool" successfully removed |
使用 lvs 命令查看以下,是否已经删除干净:
[root@localhost ~]# lvs -a | |
LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert | |
root cl -wi-ao---- 15.00g | |
swap cl -wi-ao---- 2.00g |
精简卷是可以创建大于可用磁盘的逻辑卷。使用精简卷,你可以管理可用空间的存储池(称为精简池),可以在应用程序需要时将其分配给任意数量的设备。精简池可以在需要时进行动态扩展,以节省成本。
