Centos8部署LVM精简逻辑卷

LVM是Linux环境中对磁盘分区进行管理的一种机制,是建立在硬盘和分区之上、文件系统之下的一个逻辑层,可提高磁盘分区管理的灵活性。RHEL5默认安装的分区格式就是LVM逻辑卷的格式

成都创新互联服务项目包括河东网站建设、河东网站制作、河东网页制作以及河东网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,河东网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到河东省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

系统环境

Centos8

创建精简池

下面我们添加一块硬盘。创建物理卷,然后创建卷组:

[root@localhost ~]# pvcreate /dev/sda
 Physical volume "/dev/sda" successfully created.
[root@localhost ~]# vgcreate vg_thin /dev/sda
 Volume group "vg_thin" successfully created
[root@localhost ~]# vgs
 VG      #PV #LV #SN Attr   VSize   VFree  
 cl        1   2   0 wz--n- 

上面已经创建好一个新的卷组了,名字为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。

[root@localhost ~]# lvcreate -V 200M -T vg_thin/thin_pool -n tp_lv_user1
 Logical volume "tp_lv_user1" created.
[root@localhost ~]# lvcreate -V 200M -T vg_thin/thin_pool -n tp_lv_user2
 Logical volume "tp_lv_user2" created.
[root@localhost ~]# lvcreate -V 200M -T vg_thin/thin_pool -n tp_lv_user3
 Logical volume "tp_lv_user3" created.
[root@localhost ~]# lvcreate -V 200M -T vg_thin/thin_pool -n tp_lv_user4
 Logical volume "tp_lv_user4" created.

Centos8中创建LVM精简逻辑卷Centos8中创建LVM精简逻辑卷

格式化并挂载精简卷

将上面创建的四个精简卷格式化为xfs格式:

[root@localhost ~]# mkfs.xfs /dev/vg_thin/tp_lv_user1
[root@localhost ~]# mkfs.xfs /dev/vg_thin/tp_lv_user2
[root@localhost ~]# mkfs.xfs /dev/vg_thin/tp_lv_user3
[root@localhost ~]# mkfs.xfs /dev/vg_thin/tp_lv_user4

创建挂载点,并挂载:

[root@localhost ~]# mkdir -p /mnt/user{1..4}
[root@localhost ~]# mount /dev/vg_thin/tp_lv_user1 /mnt/user1
[root@localhost ~]# mount /dev/vg_thin/tp_lv_user2 /mnt/user2
[root@localhost ~]# mount /dev/vg_thin/tp_lv_user3 /mnt/user3
[root@localhost ~]# mount /dev/vg_thin/tp_lv_user4 /mnt/user4

向这四个目录写入一些文件:

[root@localhost ~]# dd if=/dev/zero of=/mnt/user1/test.img bs=1M count=100
[root@localhost ~]# dd if=/dev/zero of=/mnt/user2/test.img bs=1M count=100
[root@localhost ~]# dd if=/dev/zero of=/mnt/user3/test.img bs=1M count=100
[root@localhost ~]# dd if=/dev/zero of=/mnt/user4/test.img bs=1M count=100

然后运行下面命令查看以下使用空间:

[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配置文件中开启超额保护,并重新创建这两个精简卷:

[root@localhost ~]# lvremove -f /dev/vg_thin/tp_lv_user5
 Logical volume "tp_lv_user5" successfully removed
[root@localhost ~]# lvremove -f /dev/vg_thin/tp_lv_user6
 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两个精简卷:

[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
 Logical volume "tp_lv_user6" created.
[root@localhost ~]# mkfs.xfs /dev/vg_thin/tp_lv_user5
[root@localhost ~]# mkfs.xfs /dev/vg_thin/tp_lv_user6
[root@localhost ~]# mkdir -p /mnt/user{5..6}
[root@localhost ~]# mount /dev/vg_thin/tp_lv_user5 /mnt/user5
[root@localhost ~]# mount /dev/vg_thin/tp_lv_user6 /mnt/user6

看一下使用的情况: 下面我们向/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                    

扩展精简池metadata的大小

元数据的当前大小仅为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

删除精简卷、精简池

要删除精简池,首先需要卸载所有文件系统,然后删除所有精简卷,最后删除精简池。

# 卸载分区
[root@localhost ~]# umount /mnt/user{1..6}
# 删除精简卷
[root@localhost ~]# lvremove -y /dev/vg_thin/tp_lv_user[1-6]
 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
# 删除精简池
[root@localhost ~]# lvremove -y /dev/vg_thin/thin_pool
 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                

总结

精简卷是可以创建大于可用磁盘的逻辑卷。使用精简卷,你可以管理可用空间的存储池(称为精简池),可以在应用程序需要时将其分配给任意数量的设备。精简池可以在需要时进行动态扩展,以节省成本。

本文题目:Centos8部署LVM精简逻辑卷
地址分享:http://www.csdahua.cn/qtweb/news7/518857.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网