一文全解:LVM(逻辑卷管理器)

lvm · 浏览次数 : 27

正文

前两篇文章已经讲了关于磁盘分区和磁盘阵列的相关内容:

一文全懂:Linux磁盘分区

一文全懂:独立冗余磁盘阵列(RAID)

但是磁盘分区完后再想扩容或者缩容就比较麻烦了,甚至很多时候不能扩容或者缩容,这时候就要用到linux非常常用的硬盘设备资源管理技术:LVM了。

LVM,英文全称叫做 "Logical Volume Manager",翻译过来的意思叫做"逻辑卷管理器",主要解决的是磁盘动态扩容或缩容的问题。

一般而言,在生产环境中无法在最初时就精确地评估每个硬盘分区在日后的使用情况,因此会导致原先分配的硬盘分区不够用。比如,伴随着业务量的增加,用于存放交易记录的数据库目录的体积也随之增加;因为分析并记录用户的行为从而导致日志目录的体积不断变大,这些都会导致原有的硬盘分区在使用上捉襟见肘。硬盘分好区或者部署为 RAID 磁盘阵列之后,再想修改硬盘分区大小就不容易了,LVM作为现在非常普及的硬盘设备资源管理技术,允许用户对硬盘资源进行动态调整,从而解决上述问题。

一、逻辑卷管理器基本概念

image-20240722134650922

上图中涉及到几个概念:

PV(Physical Volume):物理卷,顾名思义,它可能是一个硬盘,也可能是一个RAID磁盘阵列。

VG(Volume Group):卷组,多个物理卷(PV)组成一个卷组。

LV(Logical Volume):逻辑卷,也即是我们探讨的核心了,它基于卷组分配管理磁盘资源。

PE(Physical Extent):基本单元,LV能管理分配的最小单位,LVM分配出来的每个空间都必须是PE的整数倍。

也就是说物理卷(PV)组成了卷组(VG),逻辑卷(LV)基于卷组(VG)分配管理基本单元(PE)。

上图中的逻辑卷A跨硬盘将若干个PE合并起来,对外直接使用逻辑卷A即可,而不用关心逻辑卷A下到底有几个硬盘。

二、逻辑卷管理实战

LVM部署时,需要逐个配置物理卷、卷组和逻辑卷,常用的部署命令如下所示:

功能 物理卷管理 卷组管理 逻辑卷管理
扫描 pvscan vgscan lvscan
创建 pvcreate vgcreate lvcreate
显示 pvdisplay vgdisplay lvdisplay
删除 pvremove vgremove lvremove
扩容 vgextend lvextend
缩容 vgreduce lvreduce

有人或许会问,为啥逻辑卷管理没有扩容和缩容的命令呢?

答:逻辑卷对应着底层的硬盘或者RAID磁盘阵列,如果它能扩容或者缩容,就没有LVM什么事儿了,哈哈。

以下操作基于Vmware虚拟机操作。

1、物理卷和卷组创建

先给虚拟机新增加两块20G的硬盘,然后开机。可以看到sdb/sdc两块硬盘已经就绪

image-20240722153944333

第一步: 让两块硬盘支持lvm技术

pvcreate /dev/sdb /dev/sdc
image-20240722154254125

第二步: 把两块硬盘设备加入到storage卷组

vgcreate storage /dev/sdb /dev/sdc
image-20240722154755946

第三步: 查看卷组状态

vgdisplay
image-20240722155042974

从上述截图中可以看到,卷组创建完成后,PE相关的参数就已经确定好了,大小是4MB,40G的空间一共划分出了10238个PE等待lvm划分逻辑卷使用。

2、逻辑卷创建

第一步: 创建逻辑卷

我们现在从storage卷组中切割出来一块201M的逻辑卷设备。

这里要注意,切割方式有两种:

  1. 按照大小切割,使用的参数是-L,比如 -L 150M表示的是切割出来150MB大小的逻辑卷;

  2. 以基本单元的个数为单位,使用的参数是-l,每个基本单元的默认大小是4MB,比如-l 37,就可以生成37*4MB=148MB大小的逻辑卷。

比较方便的肯定是根据大小进行切割:

lvcreate -n kdyzm_lv -L 201 storage
image-20240722203327517

创建是成功了,但是可以看到它提示了个信息:Rounding up size to full physical extent 204.00 MiB。这个意思就是四舍五入创建了204MB的逻辑卷设备。为什么呢,我们明明创建的是201MB大小,它擅自给改成了204MB?答案是我们创建的大小必须是PE(Physical Extent,基本单元)的整数倍,PE大小是4MB,所以就给修正成了204MB。

Linux 系统会把 LVM 中的逻辑卷设备存放在/dev 设备目录中(实际上就是个快捷方式),同时会以卷组的名称来建立一个目录,其中保存了逻辑卷的设备映射文件(即/dev/卷组名称/逻辑卷名称)。

第二步: 格式化和挂载

如果使用了逻辑卷管理器,不建议使用xfs文件系统,据说xfs和lvm的兼容性并不好。所以接下来使用ext4来格式化硬盘。

image-20240723141604629

当然为了挂载重启后不失效,需要将挂载信息写入到/etc/fstab文件中,此处不赘述。

3、逻辑卷扩容

使用逻辑卷最大的用处就是可以为它动态扩容:卷组由若干块硬盘组成,用户在使用存储设备时感知不到设备底层的架构和布局,更不用关心底层是由多少块硬盘组成的,只要卷组中有足够的资源,就可以一直为逻辑卷扩容。

逻辑卷扩容的步骤:取消挂载->逻辑卷扩容->检查硬盘完整性->重置设备在系统中的容量->重新挂载硬盘设备

第一步: 取消挂载

扩容前请一定要记得卸载设备和挂载点的关联:umount /kdyzm_lv

第二步: 逻辑卷扩容

将逻辑卷/dev/storage/kdyzm_lv的容量从204.00 MB扩容到300MB

lvextend -L 300M /dev/storage/kdyzm_lv 
image-20240723144057857

同时,它也提示了“Size of logical volume storage/kdyzm_lv changed from 204.00 MiB (51 extents) to 300.00 MiB (75 extents).”,这个逻辑卷原来的容量是204M(51个基本单元),现在扩容到了300M(75个基本单元)。

第三步: 检查硬盘完整性

确认目录结构、内容和文件内容没有丢失。一般情况下没有报错,均为正常情况。

 e2fsck -f /dev/storage/kdyzm_lv 
image-20240723144607332

第四步: 重置设备在系统中的容量

刚刚是对 LV(逻辑卷)设备进行了扩容操作,但系统内核还没有同步到这部分新修改的信息,需要手动进行同步。

resize2fs /dev/storage/kdyzm_lv 
image-20240723144821755

第五步: 重新挂载硬盘

mount /dev/storage/kdyzm_lv /kdyzm_lv
image-20240723145139653

需要注意的是这里显示的容量是287M,而非300M,要比我们当初设计的扩容容量小一些,这个原因是硬件厂商的制造标准是1M=1000KB,1KB=1000B;在计算机系系统中则是1M=1024KB,1KB=1024B。因此硬盘容量会有些“缩水”,300M的硬盘最终会被识别为 300MB*1000K*1000B/1024B/1024K=286.1022MB ,大概的算法就是这么算的。

4、缩小逻辑卷

缩容操作数据丢失的风险会比较大,所以Linux系统规定,为了保证数据安全,在对LVM逻辑卷进行缩容操作之前,必须先检查文件系统的完整性。完整的缩容步骤如下:

取消挂载->检查文件系统完整性->通知系统内核即将缩容->逻辑卷缩容

第一步: 取消挂载

 umount /kdyzm_lv

第二步: 检查文件系统的完整性。

上面说过,检查文件系统完整性是Linux系统强制要求的,如果跳过这一步骤,就会有如下提示

image-20240723160141292

要求必须先运行命令e2fsck -f /dev/storage/kdyzm_lv,那就按照要求,先运行该命令

e2fsck -f /dev/storage/kdyzm_lv
image-20240723160419763

第三步: 通知系统内核将逻辑卷容量缩小到100M

resize2fs /dev/storage/kdyzm_lv 100M
image-20240723160650082

运行该命令没有报错,说明内核通过计算觉得缩容不会有问题,所以批准了缩容操作。

第四步: 逻辑卷缩容

通过lvreduce命令将逻辑卷的容量缩小到100M

lvreduce -L 100M /dev/storage/kdyzm_lv 
image-20240723161043511

运行完命令,它还会提示下该命令有风险,要对执行命令进行二次确认,输入y即可。

**第五步: ** 重新挂载系统

image-20240723161406733

这样就完成了缩容。

5、删除逻辑卷

删除逻辑卷,需要依次删除逻辑卷、卷组、物理卷设备,顺序不可颠倒。

第一步: 取消挂载

删除/etc/fstab文件中记录的挂载信息,取消挂载关联。

umount /kdyzm_lv

由于没有写/etc/fstab文件,所以这里不需要删除相关信息。

第二步: 删除逻辑卷

lvremove /dev/storage/kdyzm_lv 
image-20240723163220630

注意这里需要二次确认。

第三步: 删除卷组

vgremove storage

这里只需要写卷组名称,因为我们当初创建卷组的时候也是这么创建的。

image-20240723163441598

第四步: 删除物理卷

pvremove /dev/sdb /dev/sdc 
image-20240723165218622

最后,欢迎关注我的博客:https://blog.kdyzm.cn

与一文全解:LVM(逻辑卷管理器)相似的内容:

一文全解:LVM(逻辑卷管理器)

一般而言,在生产环境中无法在最初时就精确地评估每个硬盘分区在日后的使用情况,因此会导致原先分配的硬盘分区不够用。比如,伴随着业务量的增加,用于存放交易记录的数据库目录的体积也随之增加;因为分析并记录用户的行为从而导致日志目录的体积不断变大,这些都会导致原有的硬盘分区在使用上捉襟见肘。硬盘分好区或者部...

头疼!卷积神经网络是什么?CNN结构、训练与优化一文全解

> 本文全面探讨了卷积神经网络CNN,深入分析了背景和重要性、定义与层次介绍、训练与优化,详细分析了其卷积层、激活函数、池化层、归一化层,最后列出其训练与优化的多项关键技术:训练集准备与增强、损失函数、优化器、学习率调整、正则化技巧与模型评估调优。旨在为人工智能学者使用卷积神经网络CNN提供全面的指

Python Django 模版全解与实战

**本文首先介绍了Django模板系统的基础知识,接着探讨了如何安装和配置Django模板系统,然后深入解析了Django模板的基本结构、标签和过滤器的用法,阐述了如何在模板中展示模型数据,最后使用一个实际项目的例子来演示如何在实际开发中使用Django模板系统。** ## Django模板系统的简

Go运算操作符全解与实战:编写更高效的代码!

本文全面探讨了Go语言中的各类运算操作符,从基础的数学和位运算到逻辑和特殊运算符。文章旨在深入解析每一种运算操作符的工作原理、应用场景和注意事项,以帮助开发者编写更高效、健壮和可读的Go代码。 简介 Go语言,作为一种现代的编程语言,不仅因为其简单易读的语法而受到欢迎,还因为它的性能和高度并发能力在

一文全懂:Linux磁盘分区

本篇文章讲了linux磁盘管理中的分区相关知识,mbr和gpt分区有何不同?从添加一块硬盘到最后挂载到系统,经历了哪些步骤?如何创建交换分区并给交换分区扩容?

一文梳理2048小游戏从开发到上云全流程

摘要:本文主要以Cocos2d Web项目2048小游戏的开发上云为例,介绍DevOps开发实践的全流程 前言 本文主要以Cocos2d Web项目2048小游戏的开发上云为例,介绍DevOps开发实践的全流程,主要涉及开发工具为华为云软件开发平台DevCloud和CocosCreator。按照整体

一文详解TensorFlow模型迁移及模型训练实操步骤

摘要:本文介绍将TensorFlow网络模型迁移到昇腾AI平台,并执行训练的全流程。然后以TensorFlow 1.15训练脚本为例,详细介绍了自动迁移、手工迁移以及模型训练的操作步骤。 本文分享自华为云社区《将TensorFlow模型快速迁移到昇腾平台》,作者:昇腾CANN。 当前业界很多训练脚本

一文讲透产品经理如何用好ChatGPT

4.0版本推出后,在中文互联网上并没有辅助产品经理工作的详细介绍。因此,我基于GPT-4,梳理了帮助产品经理全流程提效的方法,整理了一些prompt,本文旨在分享这些收获,希望能抛砖引玉。

JDK中动态库加载路径问题,一文讲清

# 前言 本周协助测试同事对一套测试环境进行扩容,我们扩容很原始,就是新申请一台机器,直接把jdk、resin容器(一款servlet容器)、容器中web应用所在的目录,全拷贝到新机器上,servlet容器和其中的应用启动没问题。以为ok了,等到测试时,web应用报错,初始化某个类出错。报错的类长下

记录一次全栈经验,所有遇到的坑。(文中无需梯子,免费使用chatGPT方法喔)

## 1、先推荐一下自己搭的网站 ### 1.1 网站地址:[chatGPT](https://www.hangyejingling.cn/) ### 1.2 建站原因 为了方便大家在国内使用chatGPT,所以我调研了一下。在国内用腾讯云使用代理访问,gpt3.5API。最后模仿了openAI的官