嵌入式 LVM范例及常用命令
2019-07-12 18:46发布
生成海报
fdisk -l 命令的输出:
Disk /dev/sda: 120.0 GB, 120034123776 bytes
255 heads, 63 sectors/track, 14593 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Device Boot Start End Blocks Id System
/dev/sda1 * 1 2330 18715693+ 7 HPFS/NTFS
/dev/sda2 3826 14593 86493960 f W95 Ext'd (LBA)
/dev/sda3 2331 3825 12008587+ 83 Linux
/dev/sda5 3826 9179 43005973+ 7 HPFS/NTFS
/dev/sda6 9180 9192 104391 83 Linux
/dev/sda7 9193 10497 10482381 83 Linux
/dev/sda8 10498 10752 2048256 82 Linux swap / Solaris
/dev/sda9 10753 10765 104391 83 Linux
/dev/sda10 10766 11982 9775521 83 Linux
/dev/sda11 11983 14593 20972826 83 Linux
Partition table entries are not in disk order
其中/dev/sda3是用分区魔术师从/dev/sda1(windows xp的c盘,当初把这个盘分得太大)分出来的。
现在要把/dev/sda3和/dev/sda11做成一个logic volume。
1. 在这两个分区上分别建立physical volume:
# pvcreate /dev/sda3 /dev/sda11
Physical volume "/dev/sda3" successfully created
Physical volume "/dev/sda11" successfully created[/code]
pvscan命令输出:
PV /dev/sda3 lvm2 [11.45 GB]
PV /dev/sda11 lvm2 [20.00 GB]
Total: 2 [31.45 GB] / in use: 0 [0 ] / in no VG: 2 [31.45 GB]
2. 使用vgcreate命令建立volume group,这个volume group就是把两个physical volume合并起来:
[code]# vgcreate xen-volume /dev/sda3 /dev/sda11
Volume group "xen-volume" successfully created[/code]
再看pvscan命令的输出,和前一次不一样了:
[code] PV /dev/sda3 VG xen-volume lvm2 [11.45 GB / 11.45 GB free]
PV /dev/sda11 VG xen-volume lvm2 [20.00 GB / 20.00 GB free]
Total: 2 [31.45 GB] / in use: 2 [31.45 GB] / in no VG: 0 [0 ]
再看看 vgdisplay命令的输出:
# vgdisplay -v xen-volume
Using volume group(s) on command line
Finding volume group "xen-volume"
--- Volume group ---
VG Name xen-volume
System ID
Format lvm2
Metadata Areas 2
Metadata Sequence No 1
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 0
Open LV 0
Max PV 0
Cur PV 2
Act PV 2
VG Size 31.45 GB
PE Size 4.00 MB
Total PE 8051
(注:PE的默认尺寸为4M,这个VG一共有8051个PE,总容量就是VG Size的值31.45GB)
Alloc PE / Size 0 / 0
Free PE / Size 8051 / 31.45 GB
VG UUID DTRys2-7H4v-0cej-CSai-08PK-munx-fCNp7N
--- Physical volumes ---
PV Name /dev/sda3
PV UUID 0y5F7N-Nk3b-ert3-pKtr-ErQp-52Uq-npF5ns
PV Status allocatable
Total PE / Free PE 2931 / 2931
PV Name /dev/sda11
PV UUID 0khn2p-QALW-N7c3-Xb60-uEXg-0QZ5-iyfHdu
PV Status allocatable
Total PE / Free PE 5120 / 5120
3. 在上面建立的名为“xen-volume”的volume group上创建一个容量为31G的,名称为“xen-lv”的logic volume:
# lvcreate -L 31G -n xen-lv xen-volume
Logical volume "xen-lv" created
查看Logic volume的device node,这个device node的命名规则是volume group + logic volume:
# ls -al /dev/mapper/
总计 0
drwxr-xr-x 2 root root 80 10-05 14:14 .
drwxr-xr-x 14 root root 3940 10-05 14:14 ..
crw------- 1 root root 10, 62 10-05 09:07 control
brw-rw---- 1 root disk 253, 0 10-05 14:14 xen--volume-xen--lv[/code]
另外,在/dev目录下有一个以volume group为名字的目录,这个目录下有一个以logic volume为名字的软链接文件,这个文件指向/dev/mapper下的device node。
# ls -al /dev/xen-volume/
总计 0
drwx------ 2 root root 60 10-05 14:14 .
drwxr-xr-x 14 root root 3940 10-05 14:14 ..
lrwxrwxrwx 1 root root 31 10-05 14:14 xen-lv -> /dev/mapper/xen--volume-xen--lv
查看Logic volume的属性:
# lvdisplay /dev/xen-volume/xen-lv
--- Logical volume ---
LV Name /dev/xen-volume/xen-lv
VG Name xen-volume
LV UUID mzd2qO-53e6-WHw2-B37n-hqjK-zYha-O3rViE
LV Write Access read/write
LV Status available
# open 0
LV Size 31.00 GB
Current LE 7936
Segments 2
Allocation inherit
Read ahead sectors 0
Block device 253:0
4. 在logic volume上建立系统:
[code]# mkfs.ext3 /dev/xen-volume/xen-lv
mke2fs 1.39 (29-May-2006)
Filesystem label=
OS type: Linux
Block size=4096 (log=2)
Fragment size=4096 (log=2)
4063232 inodes, 8126464 blocks
406323 blocks (5.00%) reserved for the super user
First data block=0
Maximum filesystem blocks=0
248 block groups
32768 blocks per group, 32768 fragments per group
16384 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208,
4096000, 7962624
Writing inode tables: done
Creating journal (32768 blocks): done
Writing superblocks and filesystem accounting information:
done
This filesystem will be automatically checked every 38 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
5. 加载logic volume到目录:
# mount /dev/xen-volume/xen-lv /xen/
查看结果:
# df
文件系统 1K-块 已用 可用 已用% 挂载点
/dev/sda7 10153988 8359088 1270784 87% /
/dev/sda6 101086 15521 80346 17% /boot
tmpfs 466256 0 466256 0% /dev/shm
/dev/sda1 18715692 14723668 3992024 79% /windows/c
/dev/sda5 43005972 42618084 387888 100% /windows/d
/dev/mapper/xen--volume-xen--lv
31995824 180288 30190244 1% /xen
6. 在/etc/fstab文件里加一行,让logic volume能够自动加载:
/dev/xen-volume/xen-lv /xen ext3 defaults 0 0
======================================================================
=======================================================================
1、术语解释:
PV(Physical Volume):物理卷,处于 LVM 最底层,可以是物理硬盘或分区。
VG(Volume Group):卷组,建立在 PV 之上,可以含有一个到多个PV。
LV (Logical Volume):逻辑卷,建立在 VG 之上,相当于原来分区的概念。不过大小可动态改变。
PE (Physical Extend):物理区域,PV 中可以用于分配的最小存储单元,可在建立 PV 时指定,如 1、2、4、8… …. 64M,同一 VG 中的所
有 PV 的 PE 应该相同。
LE (Logical Extend):逻辑区域,LV 中可以用于分配的最小存储单元,取决于 LV 所在 PV 中 PE 的大小。
VGDA (Volume Group Descriptor Area):卷组描述区域,存在于每个PV 中,用于描述该 PV 本 PV 所含 VG、VG 中的 LV 以及 LV 中的物理区域分配等信息,在使用 pvcreate 命令建立 PV 时建立。
2、LVM创建过程:
建立 LVM 类型的分区
建立 LVM 物理卷
建立 LVM 卷组
建立 LVM 逻辑卷
建立文件系统
挂接文件系统
使用文件系统
3、PV 相关命令和 LVM物理卷管理相关的命令包括:
pvdisplay:显示PV属性
pvscan:在系统所有硬盘上查找PV
pvcreate:创建PV(在PV上初始化 VGDA)
pvdata:显示PV上的 VGDA信息
pvchange:改变PV属性
pvmove:在PV间移动PE/LE
4、VG 相关命令和 LVM 卷组管理相关的命令包括:
vgdisplay:显示VG卷组属性
vgscan:查找系统现有VG卷组
vgcreate:创建VG卷组(在 VG 上初始化VGDA)
vgdata:显示VG卷组上的 VGDA信息
vgchange:改变VG卷组属性
vgmove:在VG卷组间移动 PE/LE
5、LV 相关命令和 LVM 逻辑卷管理相关的命令包括:
lvdisplay:显示LV卷组属性
lvscan:查找系统现有LV卷组
lvcreate:创建LV卷组(在LV上初始化 LVDA)
lvdata:显示LV卷组上的LVDA信息
lvchange:改变 LV卷组属性
lvmove:在LV卷组间移动PE/LE
一、 前言
每个Linux使用者在安装Linux时都会遇到这样的困境:在为系统分区时,如何精确评估和分配各个硬盘分区的容量,因为系统管理员不但要考虑到当前某
个分区需要的容量,还要预见该分区以后可能需要的容量的最大值。因为如果估计不准确,当遇到某个分区不够用时管理员可能甚至要备份整个系统、清除硬盘、重新对硬盘分区,然后恢复数据到新分区。
虽然现在有很多动态调整磁盘的工具可以使用,例如PartationMagic等等,但是它并不能完全解决问题,因为某个分区可能会再次被耗尽;另外一个方面这需要重新引导系统才能实现,对于很多关键的服务器,停机是不可接受的,而且对于添加新硬盘,希望一个能跨越多个硬盘驱动器的文件系统时,分区调整程序就不能解决问题。
因此完美的解决方法应该是在零停机前提下可以自如对文件系统的大小进行调整,可以方便实现文件系统跨越不同磁盘和分区。幸运的是Linux提供的逻辑盘卷 管理(LVM,Logical
Volume Manager)机制就是一个完美的解决方案。
LVM是逻辑盘卷管理(Logical VolumeManager)的简称,它是Linux环境下对磁盘分区进行管理的一种机制,LVM是建立在硬盘和分区之上的一个逻辑层,来提高磁盘分区管理的灵活性。
通过LVM系统管理员可以轻松管理磁盘分区,如:将若干个磁盘分区连接为一个整块的卷组(volumegroup),形成一个存储池。管理员可以在卷组上随意创建逻辑卷组(logicalvolumes),并进一步在逻辑卷组上创建文件系统。管理员通过LVM可以方便的调整存储卷组的大小,并且可以对磁盘存储按照组的方式进行命名、管理和分配,例如按照使用用途进行定义:“development”和“sales”,而不是使用物理磁盘名“sda”和“sdb”。而且当系统添加了新的磁
盘,通过LVM管理员就不必将磁盘的文件移动到新的磁盘上以充分利用新的存储空间,而是直接扩展文件系统跨越磁盘即可。
二、LVM基本术语
前面谈到,LVM是在磁盘分区和文件系统之间添加的一个逻辑层,来为文件系统屏蔽下层磁盘分区布局,提供一个抽象的盘卷,在盘卷上建立文件系统。首先我们讨论以下几个LVM术语:
物理存储介质(The physical media)
这里指系统的存储设备:硬盘,如:/dev/hda1、/dev/sda等等,是存储系统最低层的存储单元。
物理卷(physical volume)
物理卷就是指硬盘分区或从逻辑上与磁盘分区具有同样功能的设备(如RAID),是LVM的基本存储逻辑块,但和基本的物理存储介质(如分区、磁盘等)比较,却包含有与LVM相关的管理参数。
卷组(Volume Group)
LVM卷组类似于非LVM系统中的物理硬盘,其由物理卷组成。可以在卷组上创建一个或多个“LVM分区”(逻辑卷),LVM卷组由一个或多个物理卷组成。
逻辑卷(logical volume)
LVM的逻辑卷类似于非LVM系统中的硬盘分区,在逻辑卷之上可以建立文件系统(比如/home或者/usr等)。
PE(physical extent)
每一个物理卷被划分为称为PE(Physical Extents)的基本单元,具有唯一编号的PE是可以被LVM寻址的最小单元。PE的大小是可配置的,默认为4MB。
LE(logical extent)
逻辑卷也被划分为被称为LE(Logical Extents)的可被寻址的基本单位。在同一个卷组中,LE的大小和PE是相同的,并且一一对应。
首先可以看到,物理卷(PV)被由大小等同的基本单元PE组成。
一个卷组由一个或多个物理卷组成,
从上图可以看到,PE和LE有着一一对应的关系。逻辑卷建立在卷组上。逻辑卷就相当于非LVM系统的磁盘分区,可以在其上创建文件系统。
下图是磁盘分区、卷组、逻辑卷和文件系统之间的逻辑关系的示意图:
和非LVM系统将包含分区信息的元数据保存在位于分区的起始位置的分区表中一样,逻辑卷以及卷组相关的元数据也是保存在位于物理卷起始处的VGDA(卷组 描述符区域)中。VGDA包括以下内容:PV描述符、VG描述符、LV描述符、和一些PE描述符 。
系统启动LVM时激活VG,并将VGDA加载至内存,来识别LV的实际物理存储位置。当系统进行I/O操作时,就会根据VGDA建立的映射机制来访问实际的物理位置。
三、 安装LVM
首先确定系统中是否安装了lvm工具:
[root@www root]# rpm –qa|grep lvm
lvm-1.0.3-4
如果命令结果输入类似于上例,那么说明系统已经安装了LVM管理工具;如果命令没有输出则说明没有安装LVM管理工具,则需要从网络下载或者从光盘装LVM rpm工具包。
四、 创建和管理LVM
要创建一个LVM系统,一般需要经过以下步骤:
1、 创建分区
使用分区工具(如:fdisk等)创建LVM分区,方法和创建其他一般分区的方式是一样的,区别仅仅是LVM的分区类型为8e。
2、 创建物理卷
创建物理卷的命令为pvcreate,利用该命令将希望添加到卷组的所有分区或者磁盘创建为物理卷。将整个磁盘创建为物理卷的命令为:
# pvcreate /dev/hdb
将单个分区创建为物理卷的命令为:
# pvcreate /dev/hda5
3、 创建卷组
创建卷组的命令为vgcreate,将使用pvcreate建立的物理卷创建为一个完整的卷组:
# vgcreate web_document /dev/hda5 /dev/hdb
vgcreate命令第一个参数是指定该卷组的逻辑名:web_document。后面参数是指定希望添加到该卷组的所有分区和磁盘。vgcreate在
创建卷组web_document以外,还设置使用大小为4 MB的PE(默认为4MB),这表示卷组上创建的所有逻辑卷都以4 MB
为增量单位来进行扩充或缩减。由于内核原因,PE大小决定了逻辑卷的最大大小,4 MB的PE决定了单个逻辑卷最大容量为256
GB,若希望使用大于256G的逻辑卷则创建卷组时指定更大的PE。PE大小范围为8 KB到512 MB,并且必须总是2
的倍数(使用-s指定,具体请参考man vgcreate)。
4、 激活卷组
为了立即使用卷组而不是重新启动系统,可以使用vgchange来激活卷组:
# vgchange -a y web_document
5、 添加新的物理卷到卷组中
当系统安装了新的磁盘并创建了新的物理卷,而要将其添加到已有卷组时,就需要使用vgextend命令:
# vgextend web_document /dev/hdc1
这里/dev/hdc1是新的物理卷。
6、 从卷组中删除一个物理卷
要从一个卷组中删除一个物理卷,首先要确认要删除的物理卷没有被任何逻辑卷正在使用,就要使用pvdisplay命令察看一个该物理卷信息:
如果某个物理卷正在被逻辑卷所使用,就需要将该物理卷的数据备份到其他地方,然后再删除。
删除物理卷的命令为vgreduce:
# vgreduce web_document /dev/hda1
7、 创建逻辑卷
创建逻辑卷的命令为lvcreate:
# lvcreate -L1500 –nwww1 web_document
该命令就在卷组web_document上创建名字为www1,大小为1500M的逻辑卷,并且设备入口为/dev/web_document
/www1(web_document为卷组名,www1为逻辑卷名)。如果希望创建一个使用全部卷组的逻辑卷,则需要首先察看该卷组的PE数,然后在创
建逻辑卷时指定:
# vgdisplay web_document| grep “Total PE”
Total PE 45230
# lvcreate -l 45230 web_document -n www1
8、 创建文件系统
推荐使用reiserfs文件系统,来替代ext2和ext3:
创建了文件系统以后,就可以加载并使用它:
# mkdir /data/wwwroot
# mount /dev/web_document/www1 /data/wwwroot
如果希望系统启动时自动加载文件系统,则还需要在/etc/fstab中添加内容:
/dev/web_document/www1 /data/wwwroot reiserfs defaults 1 2
9、 删除一个逻辑卷
删除逻辑卷以前首先需要将其卸载,然后删除:
# umount /dev/web_document/www1
# lvremove /dev/web_document/www1
lvremove—do you really want to remove “/dev/web_document/www1”? [y/n]: y
lvremove—doing automatic backup of volume group “web_document”
lvremove—logical volume “/dev/web_document/www1”successfully removed
10、 扩展逻辑卷大小
LVM提供了方便调整逻辑卷大小的能力,扩展逻辑卷大小的命令是lvcreate:
# lvextend -L12G/dev/web_document/www1
lvextend—extending logical volume “/dev/web_document/www1”to 12 GB
lvextend—doing automatic backup of volume group “web_document “
lvextend—logical volume “/dev/web_document/www1”successfully extended
上面的命令就实现将逻辑卷www1的大小扩招为12G。
# lvextend -L+1G/dev/web_document/www1
lvextend—extending logical volume “/dev/web_document/www1”to 13 GB
lvextend—doing automatic backup of volume group “web_document “
lvextend—logical volume “/dev/web_document/www1”successfully extended
上面的命令就实现将逻辑卷www1的大小增加1G。
增加了逻辑卷的容量以后,就需要修改文件系统大小以实现利用扩充的空间。笔者推荐使用reiserfs文件系统来替代ext2或者ext3。因此这里仅仅
讨论reiserfs的情况。Reiserfs文件工具提供了文件系统大小调整工具:resize_reiserfs。对于希望调整被加载的文件系统大
小:
# resize_reiserfs -f /dev/web_document/www1
一般建议最好将文件系统卸载,调整大小,然后再加载:
# umount /dev/web_document/www1
# resize_reiserfs /dev/web_document/www1
# mount -treiserfs /dev/web_document/www1 /data/wwwroot
对于使用ext2或ext3文件系统的用户可以考虑使用工具
ext2resize。
http://sourceforge.net/projects/ext2resize
11、 减少逻辑卷大小
使用lvreduce即可实现对逻辑卷的容量,同样需要首先将文件系统卸载:
12、删除
lvremove /dev/*
vgremove /dev/*
# umount /data/wwwroot
# resize_reiserfs -s-2G/dev/web_document/www1
# lvreduce -L-2G/dev/web_document/www1
# mount -treiserfs /dev/web_document/www1 /data/wwwroot
五、 总结
根据上面的讨论可以看到,LVM具有很好的可伸缩性,使用起来非常方便。可以方便地对卷组、逻辑卷的大小进行调整,更进一步调整文件系统的大小。如果希望了解更多信息,请参考LVM-HOWTO。
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮