LVM可以理解为可扩展的设备;在设备空间不足的时候,保证其在原始数据不变的情况下增大设备的存储大小。那么,要达到这种效果,我们得把可用设备先比变为物理卷,再把物理卷处理为物理卷组,最后成为LVM逻辑卷!现在对以下概念做解释:

物理分区  p ---->虚拟机可用的设备

物理卷  pv  ---->被lv命令处理过的物理分区

物理卷组 vg ---->被组装到一起的物理卷

图里扩展 pe ---->lvm设备的最小存储单元,lvm是pe的整数倍

逻辑卷 lvm  ---->直接使用的设备,可以增大缩小并保持原有数据

   df  -H   /mnt   ## 统计时单位10^n,总量除以1000
   df  -h   /mnt   ## 统计时单位为2^n,总量除以1024

1、LVM的创建

1)步骤:

分区并设定分区标签为8e (使用fdisk /dev/vdb 中,使用t来修改分区标签为8e)

pvcreate /dev/vdb1          ## 把/dev/vdb1处理为物理卷
vgcreate vg0 /dev/vdb1      ## 把物理卷处理为物理卷组,且命名为vg0
lvcreate -L  20M  -n  lv0  vg0   ## 再vg0中取出大小为20M的空间给lv0
mkfs.xfs  /dev/vg0/lv0      ##把lv0设备进行格式化
mount /dev/vg0/lv0   /mnt   ##挂载
df  -H  /mnt                ## 查看lv0的信息

2)示例:把/dev/vdb1创建为lvm设备

此时,我们可以看到/mnt的大小为18M,

2.LVM支持热拉伸

1)当vg中的剩余容量充足情况
lvextend  -L   80M   /dev/vg0/lv0      ##拉伸设备        
xfs_grows   /dev/vg0/lv0               ##拉伸文件系统

示例: 扩大LV0的容量(提示LV0设备最大可以到52M)

2)当vg中容量不足时
再次建立分区并修改标签为8E
pvcreate   /dev/vdb2        ## 拉伸物理卷组
vgextend   vg0   /dev/vdb2
lvextend  -L   80M   /dev/vg0/lv0
xfs_grow   /dev/vg0/lv0
pvs     ##查看pv信息
vgs     ##查看vg信息
lvs     ## 查看lv信息
df  -H   ## 查看挂载信息
df -H  /dev/vg0/lv0

示例: 建立分区/dev/vdb2并进行相关操作加入vg0中

[root@localhost ~]# partprobe

注意:xfs文件系统不可以缩减,设备可以

3.对ext文件系统的设备的拉伸及缩减
1)查看当前挂载设备的文件类型,并将其格式化为ext

显示/dev/mapper/vg0-lv0的类型为xfs

对数据进行格式化,并查看结果:

[root@localhost ~]# mkfs.ext4 /dev/vg0/lv0   

2)对ext文件类型进行拉伸
lvextend  -L  250M  /dev/vg0/lv0   ##此时,lvs显示结果为252
resize2fs  /dev/vg0/lv0      ##拉伸文件系统
3)缩减lvm:
卸载/mnt设备后,使用命令-- e2fsck  -f  /dev/vg0/lv0--进行扫描,确定设备数据的大小(现在为52M)

使用命令--resize2fs  /dev/vg0/lv0 40M --缩减文件系统大小(不可以比设备大)

缩减完文件系统后,对lv进行缩减

[root@localhost ~]# lvreduce -L 40M  /dev/vg0/lv0

##重新指定,并提示是否缩减设备

[root@localhost ~]# lvs
  LV   VG   Attr       LSize  Pool Origin Data%  Move Log Cpy%Sync Convert
  lv0  vg0  -wi-ao---- 40.00m  

4)缩减vg
vgreduce   vg0  /dev/vdb2    ##取出多余的设备

5)移动空闲pv
pvmove /dev/vdb1   /dev/vdb2  ## 把设备1中的数据移到2中
vgreduce   vg0  /dev/vdb1    ##从组中移出多余的设备2
pvremove  /dev/vdb1    ## 把空闲vdb1中pv中移除

4.lvm 快照
    当在文件中写入东西后,卸载设备,此时看不到里面的东西。这时需要做一个快照出来。快照的大小取决与要写入文件中的大小. 

lvcreate  -L  32M  -n  lv0-backup  -s  /dev/vg0/lv0  ## 文件大小为40M 

umount /mnt     ##卸载后的lv0-backup,不可重新挂载
lvremove /dev/vg0/lv0-backup     ##移除快照
lvcreate  -L  40M  -n  lv0-backup  -s  /dev/vg0/lv0  ## 文件大小为40M
mount /dev/vg0/lv0   /mnt    ##检测文件是否恢复 

示例:快照重新照,还原原始数据

首先对LV0中数据进行查看,并创建32M的快照,在快照中创建文件(执行以下操作 )

对快照中的文件进行复原时,先删除快照,再重新创建一个!

5.lvm的删除

使用命令lvremove  /dev/vg0/lv0-backup来删除快照

使用命令 lvremove  /dev/vg0/lv0 删除lv0

使用命令vgremove   vg0 删除物理卷组vg0

使用命令pvremoce  /dev/vdb2 删除物理卷pv

注意: 删除的时候,按照建立的顺序的逆序;及先删除快照,再依次删除lv、vg、pv即可

Linux之LVM设备的管理的更多相关文章

  1. 【Linux】LVM 逻辑卷管理

    LVM - 逻辑卷管理 简介 LVM(Logical Volume Manager), 即逻辑卷管理,是Linux环境下对磁盘分区进行管理的一种机制. 相关名词 PV(physical volume) ...

  2. Linux之LVM逻辑卷管理

    LVM逻辑卷管理 LVM机制:PV物理卷,VG卷组,LV逻辑卷. --功能-- --物理卷管理-- --卷组管理-- --逻辑卷管理-- create(建立) pvcreate vgcreate lv ...

  3. Linux中LVM逻辑卷管理

    一.简介 LVM是逻辑盘卷管理(Logical Volume Manager)的简称,它是Linux环境下对磁盘分区 进行管理的一种机制,LVM是建立在硬盘和分区之上的一个逻辑层,来提高磁盘分区管理的 ...

  4. Linux:使用LVM进行磁盘管理

    LVM的概念 LVM 可以实现对磁盘的动态管理,在磁盘不用重新分区的情况下动态调整文件系统的大 小,利用 LVM 管理的文件系统可以跨越磁盘. "/boot"分区用于存放系统引导文 ...

  5. Linux LVM卷组管理

    Linux LVM卷组管理 由于传统的磁盘管理不能对磁盘进行磁盘管理,因此诞生了LVM技术,LVM技术最大的特点就是对磁盘进行动态管理. 由于LVM的逻辑卷的大小更改可以进行动态调整,且不会出现丢失数 ...

  6. Linux 系统 LVM(Logical Volume Manager)逻辑卷管理

    一.前言 每个Linux使用者在安装Linux时都会遇到这样的困境:在为系统分区时,如何精确评估和分配各个硬盘分区的容量,因为系统管理员不但要考虑到 当前某个分区需要的容量,还要预见该分区以后可能需要 ...

  7. 【转载】Linux磁盘管理:LVM逻辑卷管理

    Linux学习之CentOS(二十五)--Linux磁盘管理:LVM逻辑卷基本概念及LVM的工作原理 这篇随笔将详细讲解Linux磁盘管理机制中的LVM逻辑卷的基本概念以及LVM的工作原理!!! 一. ...

  8. linux LVM逻辑卷管理

    什么是LVM LVM是逻辑卷管理(Logical Volume Manager)的简称,它是建立在物理存储设备之上的一个抽象层,允许你生成逻辑存储卷,与直接使用物理存储在管理上相比,提供了更好灵活性. ...

  9. linux入门系列13--磁盘管理之RAID、LVM技术

    前一篇文章学习了磁盘分区.格式化.挂载等相关知识,本文将讲解RAID和LVM技术. 磁盘管理操作主要是运维人员用的较多,如果只是单纯的开发人员,可以先略过本文.但是在很多小公司里往往都是一人多用,运维 ...

随机推荐

  1. java单例模式之懒汉式分析

    转自:http://blog.csdn.net/withiter/article/details/8140338 今天中午闲着没事,就随便写点关于Java单例模式的.其实单例模式实现有很多方法,这里我 ...

  2. linux 登录数据库

    -h   地址 (例如:127.0.0.1,localhost) mysql -h 127.0.0.1 -u root -p

  3. spark client + yarn计算

    前提:完成hadoop + kerberos安全环境搭建. 安装配置spark client: 1. wget https://d3kbcqa49mib13.cloudfront.net/spark- ...

  4. IoC控制反转与DI依赖输入

    IoC (Inversion of Control)即控制反转,是面向对象编程中的一种设计原则.它把传统上由程序代码直接操控的对象的调用权交给容器,通过外部容器来实现对象组件的装配和管理. 简单来说, ...

  5. mongodb入门很简单(1)

    mongodb简介: 如前边介绍的两个键-值数据库: memcached和redis属于(key/value)数据库: 而mongodb是文档数据库:存储的是文档(Bson->json的二进制) ...

  6. 【纯代码】Swift-自定义PickerView单选(可修改分割线颜色、修改字体大小、修改字体颜色。)(可根据需要自己扩展)

    typealias PopPickerViewCallBackClosure = (_ resultStr:NSString?) -> () class PopPickerView : UIVi ...

  7. Commons之Commons-io

    转载自(https://my.oschina.net/u/2000201/blog/480071) 1  概述 Commons IO是针对开发IO流功能的工具类库. 主要包括六个区域: 工具类——使用 ...

  8. Mysql CASE WHEN 用法

    select sum(1) as col_0_0_, sum(case vciinfo.useable when -1 then 1 else 0 end) as col_1_0_, sum(case ...

  9. SpringBoot中使用log4j日志

    一:引入jar包 使用SpringBoot创建项目的时候,pom文件引入了spring-boot-starter,其中包含了spring-boot-starter-logging,该依赖内容就是Spr ...

  10. u-boot-2015.07 autoconf.mk生成过程分析

    1.u-boot2015.7版本编译没有在顶层目录中生成.config文件,而生成了include/autoconf.mk和include/autoconf.mk.dep两个文件,并在每个模块编译的时 ...