嵌入式 LVM范例及常用命令

来源:互联网 发布:安卓内存优化神器 编辑:程序博客网 时间:2024/06/11 19:26
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。

0 0
原创粉丝点击