LVM常规操作记录梳理 [扩容、缩容、快照等]

 基本介绍

Linux用户安装Linux 操作系统时遇到的一个最常见的难以决定的问题就是如何正确地给评估各分区大小,以分配合适的硬盘空间。随着 Linux的逻辑盘卷管理功能的出现,这些问题都迎刃而解,
lvm是逻辑盘卷管理(Logical Volume Manager)的简称,它是 Linux环境下对磁盘分区进行管理的一种机制, LVM是建立在硬盘和分区之上的一个逻辑层,来提高磁盘分区管理的灵活性。

LVM基本术语
1)物理存储介质:这里指系统的存储设备:硬盘,如: /dev/hda、/dev/sda等等,是存储系统最低层的存储单元。
2)物理卷physical volume (PV )
  物理卷就是指硬盘分区或从逻辑上与磁盘分区具有同样功能的设备(如 RAID),是 LVM的基本存储逻辑块
3)卷组Volume Group (VG )
  LVM卷组由一个或多个物理卷组成,但是更确切的说,它包含由这些物理卷提供的许多PE。
4)逻辑卷logical volume (LV )
  这里是我们存储信息的地方,在逻辑卷之上可以建立文件系统 (比如/home或者 /usr等)。
5)PE(physical extent )
  每一个物理卷被划分为称为 PE的基本单元,具有唯一编号的 PE是可以被 LVM寻址的最小单元。 PE的大小是可配置的,默认为 4MB。

具体操作
1)创建分区
[root@test-server ~]# fdisk -l                        #查看磁盘情况
[root@test-server ~]# fdisk /dev/sda            #进入磁盘(可以依次按键p->n->e->回车->回车->w,即用此磁盘所有空闲空间创建分区)
 Command (m for help): n                             #n 为添加一个分区, p查看分区
 First cylinder (2898-10443, default 2898):         #按Enter 键决定
 Using default value 2898                                   #起始柱面选择默认值                                                                                                                                                                                                
  Last cylinder or +size or +sizeM or +sizeK (289810443, default 10443): +2G             #   给2G的大小
Command (m for help): t                                   #更改分区类型
Partition number (1-5): 5                                   # 选着分区
Hex code (type L to list codes): l                       #分区类型列表

Hex code (type L to list codes):8e                    #将新添加的分区标注成 lvm
Command (m for help): p                                 #查看分区表
/dev/sda5            2756        2999     1959898+  8e  Linux LVM
Command (m for help): w                                 #保存
[root@test-server ~]# partprobe /dev/sda             #系统识别分区(代替重启)
[root@test-server ~]# mkfs.ext4 /dev/sda5           #格式化新添加的分区

2)PV创建    ("yum install lvm2" 安装lvm的操作命令,如pvcreate)
[root@test-server ~]# pvcreate /dev/sda5                 #创建pv
 Writing physical volume data to disk "/dev/sda5"
 Physical volume "/dev/sda5" successfully created
[root@test-server ~]# pvs                                          #或pvdisplay,查看当前pv的信息
 PV         VG   Fmt  Attr PSize PFree
 /dev/sda5       lvm2 a--  1.87G 1.87G

3)VG创建
[root@test-server ~]# vgcreate vg0 /dev/sda5           #vg0 为当前vg的名
 Volume group "vg0" successfully created
[root@test-server ~]# vgs                                           #或vgdispaly,查看vg详细信息,会显示PE数
 VG   #PV #LV #SN Attr   VSize VFree
 vg0    1   0   0 wz--n- 1.87G 1.87G

4)LV创建(使用vgdisplay查看"Free  PE"中可用的空间来制作LVM。比如这里查看到Free PE空间为500M,则最大只能使用500M来制作lvm)
# lvcreate  -L +大小 -n lv_name vg_name      (指定逻辑卷的大小,单位为"kKmMgGtT"字节)
# lvcreate  -l +PE数  -n  lv_name vg_name      (或"lvcreate -l +百分比FREE -n lv_name vg_name"命令,即使用卷组剩余所有空间的百分比)
[root@test-server ~]# lvcreate -L +500M -n lv01 vg0
 Logical volume "lv01" created
[root@test-server ~]# lvs                                          #或lvdispaly,查看lv 的信息
LV   VG   Attr   LSize   Origin Snap%  Move Log Copy%  Convert
 lv01 vg0  -wi-a- 500.00M                                      
You have mail in /var/spool/mail/root
[root@test-server ~]# mkfs.ext4 /dev/vg0/lv01             #格式化

5)挂载使用LVM
[root@test-server ~]# mkdir /mnt/lv01                                  #建立挂载目录
[root@test-server ~]# mount /dev/vg0/lv01 /mnt/lv01           #将制作的lvm挂载起来
[root@test-server ~]# df -h
[root@test-server ~]# touch /mnt/lv01/lv.file
[root@test-server ~]#ls /mnt/lv01

LVM的增大
比如原来lv大小500M ,现在要拉伸分区到 800M。
前提是vg0里面还有剩余空间(vgdispaly查看Free PE)。
先使用vgdisplay查看vg0组是否还有多余的空间.
[root@test-server ~]# vgdisplay
.......
 Alloc PE / Size       1277 / 500M
Free  PE / Size       490 / 300M
 VG UUID               hYScku-I097-bxMg-iUKq-WKnd-gEfQ-1wn5nU
...................

======================================================
如没有剩余,需要vgextend扩建。比如创建一个分区/dev/sdb1
# pvcreate /dev/sdb1
# vgextend vg0 /dev/sdb1       扩容到vg0组里
# vgdisplay      查看vg0多余的空间
======================================================

[root@test-server ~]# lvextend -L +300M /dev/vg0/lv01      #使用 "-L +300M"  或是 "-l +490" 都可以
Logical volume lv01 successfully resized                          # 或者直接使用" lvextend -l +100%FREE /dev/vg0/lv0 "命令,即使用卷组剩余所有空间。
[root@test-server ~]# resize2fs /dev/vg0/lv01                     #拉伸文件系统
[root@test-server ~]# lvs
LV VG Attr LSize Origin Snap% Move Log Copy% Convert
lv01 vg0 -wi-ao 800.00M                                                      #大小变成了 800M

LVM的减小
[root@test-server ~]# umount  /dev/vg0/lv01                           #卸载逻辑卷 /dev/vg0/lv01,或者卸载/mnt/lv01目录也可以
[root@test-server ~]# df -h                                                      #查看
[root@test-server ~]# e2fsck  -f  /dev/vg0/lv01                         #磁盘校验
[root@test-server ~]# resize2fs  /dev/vg0/lv01  500M              #回缩文件系统到 500M
[root@test-server ~]# lvreduce  -L  500M  /dev/vg0/lv01           #回缩分区到 500M
    WARNING: Reducing active logical volume to 500.00 MB
    THIS MAY DESTROY YOUR DATA (filesystem etc.)
    Do you really want to reduce lv01? [y/n]: y  
[root@test-server ~]# lvs
 LV   VG   Attr   LSize   Origin Snap%  Move Log Copy%   Convert
  lv01 vg0  -wi-a- 500.00M                                                          #此时已变成500M大小
[root@test-server ~]# mount  /dev/vg0/lv01   /mnt/lv01              #重新挂载分区
[root@test-server ~]# df -h                                                      #查看
[root@test-server ~]# ls /mnt/lv01                                           #查看文件

===========================================================
特别注意的是:
resize2fs命令         针对的是ext2、ext3、ext4文件系统。
xfs_growfs命令      针对的是xfs文件系统
===========================================================

LVM的系统快照
原理:系统快照(snapshot)是 lvm的另外一种重要的功能,快照就是将当时的数据记录下来,就好像照相记录一样,以后数据有任何改动,原数据会被移动到快照区,没有被改变的区域则由快照区与文件系统共享。
由于快照区和原本的 LV共享很多 PE,所以快照区与被快照的区域必须在同一个 VG上
操作:
以上面创建的 lv01为例
1)挂载lvm
[root@test-server ~]# mount /dev/vg0/lv01 /mnt/lv01    
[root@test-server ~]# cd /mnt/lv01
[root@test-server  lv01]# touch {a,b,c}{a,b,c}
[root@test-server  lv01]# ls
aa  ab  ac  ba  bb  bc  ca  cb  cc   lost+found  lv.file  restoresymtable
2)为lvm创建快照
[root@test-server  lv01]# lvcreate -L 64M -s -n lv-backup /dev/vg0/lv01
 Logical volume "lv-backup" created
3)挂载快照
[root@test-server  lv01]# mkdir /mnt/lv-backup
[root@test-server  mnt]# mount -o ro /dev/vg0/lv-backup /mnt/lv-backup/
4)备份快照
[root@test-server  tmp]# dump -0u -f /tmp/lv-backup.dump /mnt/lv-backup/                       #备份
 DUMP: Date of this level 0 dump: Sun Nov 11 14:53:31 2012
 DUMP: Dumping /dev/mapper/vg0-lv--backup (/mnt/lv-backup) to /tmp/lv-backup.dump
5)删除快照
[root@test-server  tmp]# umount /mnt/lv-backup/
[root@test-server  tmp]# lvremove /dev/vg0/lv-backup
Do you really want to remove active logical volume lv-backup? [y/n]: y
 Logical volume "lv-backup" successfully removed
6)清空/dev/vg0/lv01下内容
[root@test-server  tmp]# umount /mnt/lv01
[root@test-server  tmp]# mkfs.ext3 /dev/vg0/lv01
mke2fs 1.39 (29-May-2006)
Filesystem label=
OS type: Linux
7)恢复数据
[root@test-server  tmp]# mount /dev/vg0/lv01 /mnt/lv01
[root@test-server  tmp]# cd /mnt/lv01
[root@test-server  lv01]# ls
lost+found
[root@test-server  lv01]# restore -rf /tmp/lv-backup.dump              #恢复
restore: ./lost+found: File exists
[root@test-server  lv01]# ls                                                             #由于之前都删除了,所以这些都是改变的部分
aa  ab  ac  ba  bb  bc  ca  cb  cc  lost+found  lv.file  restoresymtable

LVM的关闭 (删除)
[root@test-server ~]# umount /mnt/lv01
[root@test-server ~]# lvremove /dev/vg0/lv01                       #删除lv
Do you really want to remove active logical volume lv01? [y/n]: y
 Logical volume "lv01" successfully removed
[root@test-server ~]# vgchange -a n vg0                               #使vg0不具有 active标志
 0 logical volume(s) in volume group "vg0" now active
[root@test-server ~]# vgremove vg0                                      #删除vg
 Volume group "vg0" successfully removed
[root@test-server ~]# pvremove /dev/sda5                            #删除pv
 Labels on physical volume "/dev/sda5" successfully wiped

#################### 贴一个虚拟机磁盘扩容实施记录 #######################
Linux服务器硬盘在线热扩容基本都是通过LVM方式实现的,所以服务器系统安装时,磁盘挂载最好选择LVM方式。我们目前采用的是XenServer虚拟化,随着业务数据的不断增加,发现部分虚拟机的/data分区空间不够用了,更闹心的是/data分区是独立分区,并不是LVM分区(这是由于XenServer虚拟化系统安装时没有选择LVM那一项,故虚机创建中选择磁盘属性时LVM选项无效)。

[root@uatdata-node01 ~]# df -h
Filesystem   Size    Used   Avail  Use% Mounted on
/dev/xvda2   99G    6.9G   87G    8%      /
tmpfs            7.8G  12K    7.8G    1%      /dev/shm
/dev/xvda1   380M 66M    294M   19%    /boot
/dev/xvda5   298G  258G  40G     88%   /data

由上面可知,数据分区/data空间已经不多了,该服务器是hadoop数据节点,每天会产生大量的数据文件到/data下,故需要紧急扩容/data分区。
操作思路:
1)为这台虚拟机新添加一个磁盘,做成LVM逻辑卷/dev/vg0/lv0,挂载到/data_new 目录下。
2)将/data目录下的数据全部拷贝到/data_new目录下,通过rsync拷贝(-avpgolr保持文件属性不变)
3)umount卸载/data和/data_new。
4)重新挂载/dev/vg0/lv0到/data下(这样做是为了保证磁盘扩容后,原来的业务程序的数据目录结构不变),并删除/data_new目录。
5)将挂载到之前/data目录下的/dev/xvda5格式化,并在线热扩容到新的/dev/vg0/lv0逻辑卷内。

操作记录:
为虚拟机添加一块新的500G的磁盘
[root@uatdata-node01 ~]# fdisk -l
........
Disk /dev/xvdb: 536.9 GB, 536870912000 bytes
255 heads, 63 sectors/track, 65270 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x54c845dd

做成lvm逻辑卷
[root@uatdata-node01 ~]# fdisk /dev/xvdb
........
分别输入:
p          #查看分区情况
n          #创建分区
p          #创建逻辑分区
1          #选择分区序列号,即盘符为/dev/xvdb1
回车     #默认从扇区起点开始
回车     #默认磁盘所有空间
w         #保存

[root@uatdata-node01 ~]# partprobe /dev/xvdb1                 #或直接执行"partprobe",这一步为更新分区表,也可以不执行,或执行有报错可以忽略
[root@uatdata-node01 ~]# yum install -y lvm2                  #安装lvm的工具

安装pv
[root@uatdata-node01 ~]# pvcreate /dev/xvdb1
[root@uatdata-node01 ~]# pvs

安装vg
[root@uatdata-node01 ~]# vgcreate vg0 /dev/xvdb1
[root@uatdata-node01 ~]# vgs

安装lv
[root@uatdata-node01 ~]# vgdisplay 
............. 
Free PE / Size 499876 / 499.99 GiB                            #先使用vgdisplay查看可以用以创建lvm的空间有多少,这里表示剩余空间为499.99G可用

[root@uatdata-node01 ~]# lvcreate -L +499.99G -n lv0 vg0
[root@uatdata-node01 ~]# lvs

格式化并挂载
[root@uatdata-node01 ~]# mkfs.ext4 /dev/vg0/lv0
[root@uatdata-node01 ~]# mkdir /data_new
[root@uatdata-node01 ~]# mount /dev/vg0/lv0 /data_new

拷贝数据
[root@uatdata-node01 ~]# rsync -avpgolr /data/ /data_new

卸载并重新挂载新增磁盘到/data目录下
[root@uatdata-node01 ~]# umount /data
[root@uatdata-node01 ~]# umount /data_new
[root@uatdata-node01 ~]# mount /dev/vg0/lv0 /data
[root@uatdata-node01 ~]# rm -rf /data_new

把之前挂载到/data目录下的/dev/xvda5分区格式化,并热扩容到新的/dev/vg0/lv0分区
[root@uatdata-node01 ~]# mkfs.ext4 /dev/xvda5
[root@uatdata-node01 ~]# pvcreate /dev/xvda5
[root@uatdata-node01 ~]# vgextent vg0 /dev/xvda5
[root@uatdata-node01 ~]# vgdisplay
..........
Free PE / Size 197898 / 198.5 GiB

[root@uatdata-node01 ~]# lvextend -L +198.5G /dev/vg0/lv0
[root@uatdata-node01 ~]# resize2fs /dev/vg0/lv0                              #拉伸文件系统
[root@uatdata-node01 ~]# lvs

最后查看下扩容后的/data盘的大小
[root@uatdata-node01 ~]# df -h
Filesystem    Size   Used   Avail   Use%   Mounted on
/dev/xvda2    99G   6.9G   87G    8%         /
tmpfs             7.8G  12K    7.8G   1%         /dev/shm
/dev/xvda1    380M  66M   294M  19%      /boot
/dev/mapper/vg0-lv0   681G 138G  509G 22%    /data
上一篇:Linux环境下vscode Cmake工程移植


下一篇:iframe中的jquery ui modal dialog 覆盖父窗口