LVM基础详细说明及动态扩容lvm逻辑卷的操做记录

 

LVM概念:
--------------------------------------------------------------------------------------------------------------------------------------------------------
它是Linux环境下对磁盘分区进行管理的一种机制,LVM是创建在硬盘和分区之上的一个逻辑层,来提升磁盘分区管理的灵活性。经过LVM系统管理员能够轻松管理磁盘分区,如:将若干个磁盘分区链接为一个整块的卷组(volume group),造成一个存储池。管理员能够在卷组上随意建立逻辑卷组(logical volumes),并进一步在逻辑卷组上建立文件系统。管理员经过LVM能够方便的调整存储卷组的大小,而且能够对磁盘存储按照组的方式进行命名、管理和分配。当系统添加了新的磁盘,经过LVM管理员就没必要将磁盘的文件移动到新的磁盘上以充分利用新的存储空间,而是直接扩展文件系统跨越磁盘便可。它的结构以下图所示:html

LVM(Logical Volume Manager),即逻辑卷管理,它是Linux环境下对磁盘分区进行管理的一种机制。
通常来讲,物理磁盘或分区之间是分隔的,数据没法跨盘或分区,而各磁盘或分区的大小固定,从新调整比较麻烦。LVM能够将这些底层的物理磁盘或分区整合起来,抽象成容量资源池,以划分红逻辑卷的方式供上层使用,其最主要的功能便是能够在无需关机无需从新格式化(准确地说,原来的部分无需格式化,只格式化新增的部分)的状况下弹性调整逻辑卷的大小。node

LVM的实现过程linux

几个名称解释
--------------------------------------------------------------------------------------------------------------------------------------------------------
PV(physical volume):物理卷在逻辑卷管理系统最底层,可为整个物理硬盘或实际物理硬盘上的分区。它只是在物理分区中划出了一个特殊的区域,用于记载与LVM相关的管理参数。 
VG(volume group):卷组创建在物理卷上,一卷组中至少要包括一物理卷,卷组创建后可动态的添加卷到卷组中,一个逻辑卷管理系统工程中可有多个卷组。
LV(logical volume):逻辑卷创建在卷组基础上,卷组中未分配空间可用于创建新的逻辑卷,逻辑卷创建后能够动态扩展和缩小空间。
PE(physical extent):物理区域是物理卷中可用于分配的最小存储单元,物理区域大小在创建卷组时指定,一旦肯定不能更改,同一卷组全部物理卷的物理区域大小需一致,新的pv加入到vg后,pe的大小自动更改成vg中定义的pe大小。
LE(logical extent):逻辑区域是逻辑卷中可用于分配的最小存储单元,逻辑区域的大小取决于逻辑卷所在卷组中的物理区域的大小。因为受内核限制的缘由,一个逻辑卷(Logic Volume)最多只能包含65536个PE(Physical Extent),因此一个PE的大小就决定了逻辑卷的最大容量,4 MB(默认) 的PE决定了单个逻辑卷最大容量为 256 GB,若但愿使用大于256G的逻辑卷,则建立卷组时须要指定更大的PE。在Red Hat Enterprise Linux AS 4中PE大小范围为8 KB 到 16GB,而且必须老是 2 的倍数。docker

将各物理磁盘或分区的系统类型设为Linux LVM,其system ID为8e,经过fdisk工具中的t命令设置安全

[root@localhost ~]# fdisk /dev/sda
...
Command (m for help): n
First cylinder (1593-3916, default 1593): 
Using default value 1593
Last cylinder, +cylinders or +size{K,M,G} (1593-3916, default 3916): +5G
...
Command (m for help): t
Partition number (1-6): 5
Hex code (type L to list codes): 8e   # 指定system ID为8e
Changed system type of partition 5 to 8e (Linux LVM)
...
Command (m for help): p
...
/dev/sda5            1593        2246     5252227+  8e  Linux LVM
/dev/sda6            2247        2900     5253223+  8e  Linux LVM
/dev/sda7            2901        3554     5253223+  8e  Linux LVM 
Command (m for help): w
...
[root@localhost ~]# partx -a /dev/sda
...
[root@localhost ~]# kpartx -af /dev/sda
...

将各物理磁盘或分区初始化为PV(physical volume,物理卷),这一阶段可以使用的命令为pvcreate、pvremove、pvscan、pvdisplay(pvs)bash

pvcreate建立物理卷oracle

  用法:pvcreate [option] DEVICEapp

  选项:dom

      -f:强制建立逻辑卷,不需用户确认工具

      -u:指定设备的UUID

      -y:全部问题都回答yes

  例 pvcreate /dev/sda5 /dev/sda6

pvscan:扫描当前系统上的全部物理卷

  用法:pvscan [option]

  选项:

      -e:仅显示属于输出卷组的物理卷

      -n:仅显示不属于任何卷组的物理卷

      -u:显示UUID

pvdisplay:显示物理卷的属性

  用法:pvdisplay [PV_DEVICE]

pvremove:将物理卷信息删除,使其再也不被视为一个物理卷

  用法:pvremove [option] PV_DEVICE

  选项:

      -f:强制删除

      -y:全部问题都回答yes

  例 pvremove /dev/sda5

[root@localhost ~]# pvcreate /dev/sda{5,6,7}   # 将三个分区初始化为物理卷
  Physical volume "/dev/sda5" successfully created
  Physical volume "/dev/sda6" successfully created
  Physical volume "/dev/sda7" successfully created
[root@localhost ~]# pvscan
  PV /dev/sda5                      lvm2 [5.01 GiB]
  PV /dev/sda6                      lvm2 [5.01 GiB]
  PV /dev/sda7                      lvm2 [5.01 GiB]
  Total: 3 [15.03 GiB] / in use: 0 [0   ] / in no VG: 3 [15.03 GiB]
[root@localhost ~]# pvdisplay /dev/sda5   # 显示物理卷sda5的详细信息
  "/dev/sda5" is a new physical volume of "5.01 GiB"
  --- NEW Physical volume ---
  PV Name               /dev/sda5
  VG Name               
  PV Size               5.01 GiB
  Allocatable           NO
  PE Size               0   # 因为PE是在VG阶段才划分的,因此此处看到的都是0
  Total PE              0
  Free PE               0
  Allocated PE          0
  PV UUID               lrNOS3-8U21-ZS8o-eyKH-HqPn-DLhX-W1ppl4
    
[root@localhost ~]# pvremove /dev/sda7   # 删除sda7的物理卷信息
  Labels on physical volume "/dev/sda7" successfully wiped
[root@localhost ~]# pvscan   # 能够看到PV列表中已无sda7
  PV /dev/sda5   VG myvg   lvm2 [5.01 GiB / 5.01 GiB free]
  PV /dev/sda6   VG myvg   lvm2 [5.01 GiB / 5.01 GiB free]
[root@localhost ~]# pvcreate /dev/sda7
  Physical volume "/dev/sda7" successfully created

建立VG(volume group,卷组)。卷组将多个物理卷整合起来(屏蔽了底层细节),并划分PE(physical extend)PE是物理卷中的最小存储单元,有点相似于文件系统中的block,PE大小可指定,默认为4M。这一阶段用到的命令有vgcreate、vgscan、vgdisplay、vgextend、vgreduce

vgcreate建立卷组

  用法:vgcreate [option] VG_NAME PV_DEVICE

  选项:

      -s:卷组中的物理卷的PE大小,默认为4M

      -l:卷组上容许建立的最大逻辑卷数

      -p:卷级中容许添加的最大物理卷数

  例 vgcreate -s 8M myvg /dev/sda5 /dev/sda6

vgscan:查找系统中存在的LVM卷组,并显示找到的卷组列表

vgdisplay:显示卷组属性

  用法:vgdisplay [option] [VG_NAME]

  选项:

      -A:仅显示活动卷组的信息

      -s:使用短格式输出信息

vgextend:动态扩展LVM卷组,它经过向卷组中添加物理卷来增长卷组的容量

  用法:vgextend VG_NAME PV_DEVICE

  例 vgextend myvg /dev/sda7

vgreduce:经过删除LVM卷组中的物理卷来减小卷组容量,不能删除LVM卷组中剩余的最后一个物理卷
  用法:vgreduce VG_NAME PV_DEVICE

vgremove:删除卷组,其上的逻辑卷必须处于离线状态

  用法:vgremove [-f] VG_NAME

  -f:强制删除

vgchange:经常使用来设置卷组的活动状态

  用法:vgchange -a n/y VG_NAME

  -a n为休眠状态,休眠以前要先确保其上的逻辑卷都离线;

  -a y为活动状态

[root@localhost ~]# vgcreate -s 8M myvg /dev/sda{5,6}   # 使用sda五、sda6建立卷组,指定PE大小为8M
  Volume group "myvg" successfully created
[root@localhost ~]# vgscan
  Reading all physical volumes.  This may take a while...
  Found volume group "myvg" using metadata type lvm2
[root@localhost ~]# vgdisplay   # 查看卷组详细信息
  --- Volume group ---
  VG Name               myvg
  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               10.02 GiB   # 卷组容量
  PE Size               8.00 MiB
  Total PE              1282   # PE总数
  Alloc PE / Size       0 / 0   # 分配的容量 
  Free  PE / Size       1282 / 10.02 GiB   # 空闲的容量
  VG UUID               5zBY8e-5Cgc-HqSo-BOiZ-02NX-77ON-NJSCbN

在卷组上建立LV(logical volume,逻辑卷)。为了便于管理,逻辑卷对应的设备文件保存在卷组目录下,为/dev/VG_NAME/LV_NAME。LV中能够分配的最小存储单元称为LE(logical extend),在同一个卷组中,LE的大小和PE是同样的,且一一对应。这一阶段用到的命令有lvcreate、lvscan、lvdisplay、lvextend、lvreduce、lvresize

lvcreate建立逻辑卷或快照

  用法:lvcreate [选项] [参数]

  选项:

      -L:指定大小

      -l:指定大小(LE数)

      -n:指定名称

      -s:建立快照

      -p r:设置为只读(该选项通常用于建立快照中)

  注:使用该命令建立逻辑卷时固然必须指明卷组,建立快照时必须指明针对哪一个逻辑卷         

  例 lvcreate -L 500M -n mylv myvg

lvscan:扫描当前系统中的全部逻辑卷,及其对应的设备文件

lvdisplay:显示逻辑卷属性

  用法:lvdisplay [/dev/VG_NAME/LV_NAME]

lvextend:可在线扩展逻辑卷空间

  用法:lvextend -L/-l 扩展的大小 /dev/VG_NAME/LV_NAME  

  选项:

      -L:指定扩展(后)的大小。例如,-L +800M表示扩大800M,而-L 800M表示扩大至800M

      -l:指定扩展(后)的大小(LE数)

  例 lvextend -L 200M /dev/myvg/mylv

lvreduce:缩减逻辑卷空间,通常离线使用

  用法:lvexreduce -L/-l 缩减的大小 /dev/VG_NAME/LV_NAME  

  选项:

      -L:指定缩减(后)的大小

      -l:指定缩减(后)的大小(LE数)

  例 lvreduce -L 200M /dev/myvg/mylv

lvremove:删除逻辑卷,须要处于离线(卸载)状态

  用法:lvremove [-f] /dev/VG_NAME/LV_NAME

  -f:强制删除

[root@localhost ~]# lvcreate -L 500M -n mylv myvg   # 建立大小为500M、名为mylv的逻辑卷
  Rounding up size to full physical extent 504.00 MiB
  Logical volume "mylv" created
[root@localhost ~]# lvscan
  ACTIVE            '/dev/myvg/mylv' [504.00 MiB] inherit
[root@localhost ~]# lvdisplay
  --- Logical volume ---
  LV Path                /dev/myvg/mylv
  LV Name                mylv
  VG Name                myvg
  LV UUID                0fPpO3-gVaI-ZKqi-xHnc-uaHk-u6of-i5wds7
  LV Write Access        read/write
  LV Creation host, time localhost.localdomain, 2015-10-18 22:05:18 +0800
  LV Status              available
  # open                 0
  LV Size                504.00 MiB  # 这里为何不是指定的500M呢,由于500M不是PE的倍数,系统会自行计算最相近的容量
  Current LE             63
  Segments               1
  Allocation             inherit
  Read ahead sectors     auto
  - currently set to     256
  Block device           253:0

格式化逻辑卷并挂载

[root@localhost ~]# mke2fs -t ext4 /dev/myvg/mylv
...
Writing inode tables: done                            
Creating journal (8192 blocks): done
Writing superblocks and filesystem accounting information: done
...
[root@localhost ~]# mkdir /data
[root@localhost ~]# mount /dev/myvg/mylv /data
[root@localhost ~]# cp /etc/inittab /data
[root@localhost ~]# ls /data
inittab  lost+found

LVM的写入模式
--------------------------------------------------------------------------------------------------------------------------------------------------------
LVM有两种写入模式:线性模式条带模式
- 线性模式即写完一个设备后再写另外一个设备
- 条带模式就有点相似于RAID0,即数据是被分散写入到LVM各成员设备上的。
由于条带模式的数据不具备安全性,且LVM并不强调读写性能,故LVM默认为线性模式,这样即便一个设备坏了,其它设备上的数据还在。

文件系统的扩展和缩减
--------------------------------------------------------------------------------------------------------------------------------------------------------
文件系统在建立时是分红多个块组(block group)的,所以文件系统的增减实际上就是以增减块组的方式实现的。在linux中,ext系列格式的文件系统是能够扩展和缩减的,而xfs格式的目前只能扩展
1)扩展文件系统
①先肯定扩展的目标大小,并确保对应卷组中有足够的空闲空间可用。若是不够,可先经过vgextend命令扩大卷组容量
# vgextend myvg /dev/sda7
②扩展逻辑卷
# lvextend -L 4G /dev/myvg/mylv
③扩展文件系统
resize2fs为ext系列文件系统大小的调整工具用法为:resize2fs 文件系统所对应的设备文件名 [大小]
# resize2fs /dev/myvg/mylv

[root@localhost ~]# vgextend myvg /dev/sda7   # 假如卷组容量不够,扩展文件系统以前先扩展卷组
  Volume group "myvg" successfully extended
[root@localhost ~]# lvextend -L +300M /dev/myvg/mylv
  Rounding size to boundary between physical extents: 304.00 MiB
  Snapshot origin volumes can be resized only while inactive: try lvchange -an
  Run `lvextend --help' for more information.
[root@localhost ~]# umount /dev/myvg/mylv_snap
[root@localhost ~]# lvremove /dev/myvg/mylv_snap  # 要增减逻辑卷,须要先删除对对应的快照卷
Do you really want to remove active logical volume mylv_snap? [y/n]: y
  Logical volume "mylv_snap" successfully removed
[root@localhost ~]# lvextend -L +300M /dev/myvg/mylv   # 逻辑卷扩大300M
  Rounding size to boundary between physical extents: 304.00 MiB
  Extending logical volume mylv to 808.00 MiB
  Logical volume mylv successfully resized
[root@localhost ~]# resize2fs /dev/myvg/mylv   # 扩展文件系统
resize2fs 1.41.12 (17-May-2010)
Filesystem at /dev/myvg/mylv is mounted on /data; on-line resizing required
old desc_blocks = 2, new_desc_blocks = 4
Performing an on-line resize of /dev/myvg/mylv to 827392 (1k) blocks.
The filesystem on /dev/myvg/mylv is now 827392 blocks long.
 
[root@localhost ~]# df -h   # 显示容量确实已扩大
...
/dev/mapper/myvg-mylv  783M   11M  732M   2% /data

2)缩减很危险,要离线
①先肯定缩减后的目标大小,并确保对应的目标逻辑卷大小足够容纳原有数据
②先卸载文件系统,并要执行强制检测
# e2fsck -f
③缩减文件系统
#resize2fs DEVICE        例如,resize2fs /dev/myvg/mylv 3G 缩减至3G

④缩减逻辑卷
# lvreduce -L 3G /dev/myvg/mylv
注:当逻辑卷有快照时是不能扩展和缩减的,除非先将快照删除.

[root@localhost ~]# umount /dev/myvg/mylv   # 缩减文件系统以前要先卸载
[root@localhost ~]# e2fsck -f /dev/myvg/mylv   # 检测文件系统
e2fsck 1.41.12 (17-May-2010)
Pass 1: Checking inodes, blocks, and sizes
Pass 2: Checking directory structure
Pass 3: Checking directory connectivity
Pass 4: Checking reference counts
Pass 5: Checking group summary information
/dev/myvg/mylv: 12/206848 files (0.0% non-contiguous), 36856/827392 blocks
[root@localhost ~]# resize2fs /dev/myvg/mylv 500M   # 缩减文件系统至500M
resize2fs 1.41.12 (17-May-2010)
Resizing the filesystem on /dev/myvg/mylv to 512000 (1k) blocks.
The filesystem on /dev/myvg/mylv is now 512000 blocks long.
[root@localhost ~]# lvreduce -L 500M /dev/myvg/mylv   # 缩减逻辑卷至500M
  Rounding size to boundary between physical extents: 504.00 MiB
  WARNING: Reducing active and open logical volume to 504.00 MiB
  THIS MAY DESTROY YOUR DATA (filesystem etc.)
Do you really want to reduce mylv? [y/n]: y
  Reducing logical volume mylv to 504.00 MiB
  Logical volume mylv successfully resized
[root@localhost ~]# mount /dev/myvg/mylv /data   # 从新挂载
[root@localhost ~]# df -h   # 显示容量确实已减少
...
/dev/mapper/myvg-mylv  485M   11M  449M   3% /data
 
[root@localhost ~]# vgchange -an myvg   # 当咱们一段时间内再也不使用卷组时,可将其休眠
  Logical volume myvg/mylv contains a filesystem in use.
  Can't deactivate volume group "myvg" with 1 open logical volume(s)
[root@localhost ~]# umount /data    # 休眠以前先卸载逻辑卷
[root@localhost ~]# umount /mnt
[root@localhost ~]# vgchange -an myvg
  0 logical volume(s) in volume group "myvg" now active
[root@localhost ~]# vgchange -ay myvg   # 从新激活卷组
  1 logical volume(s) in volume group "myvg" now active
[root@localhost ~]# vgremove myvg   # 若打算之后都再也不使用,可删除卷组
Do you really want to remove volume group "myvg" containing 1 logical volumes? [y/n]: y
Do you really want to remove active logical volume mylv? [y/n]: y
  Logical volume "mylv" successfully removed
  Volume group "myvg" successfully removed

snapshot(快照)
--------------------------------------------------------------------------------------------------------------------------------------------------------
snapshot是像照相同样将当前的系统信息保存下来。
当建立一个snapshot的时候,仅拷贝原始卷里数据的元数据(meta-data)。建立的时候,并不会有数据的物理拷贝,所以snapshot的建立几乎是实时的,当原始卷上有写操做执行时,snapshot跟踪原始卷块的改变,这个时候原始卷上将要改变的数据在改变以前被拷贝到snapshot预留的空间里,所以这个原理的实现叫作写时复制(copy-on-write)。
在写操做写入块以前,原始数据被移动到 snapshot空间里,这样就保证了全部的数据在snapshot建立时保持一致。而对于snapshot的读操做,若是是没有修改过的块,那么会将读操做直接重定向到原始卷上,若是是已经修改过的块,那么就读取拷贝到snapshot中的块。

■建立快照卷:

lvcreate [选项] [参数]

选项:
-L:指定大小

-l:指定大小(LE数)

-n:指定名称

-s:建立快照

-p r:设置为只读

例如 lvcreate -s -L 512M -n mylv_snap -p r /dev/myvg/mylv # 针对逻辑卷mylv建立大小为512M的只读快照

注:建立快照前需将针对的逻辑卷临时改成只读,建立完毕后再改成读写,例如
- 建立快照前:mount -o remount,ro /dev/myvg/mylv /data
- 建立快照后:mount -o remount,rw /dev/myvg/mylv /data

[root@localhost ~]# mount -o remount,ro /dev/myvg/mylv /data   # 建立快照卷以前先将对应的逻辑卷改成只读
[root@localhost ~]# lvcreate -s -L 512M -n mylv_snap /dev/myvg/mylv  # 建立大小为512M的快照
  Logical volume "mylv_snap" created
[root@localhost ~]# mount -o remount,rw /dev/myvg/mylv /data   # 将逻辑卷改回为读写
[root@localhost ~]# mount /dev/myvg/mylv_snap /mnt
[root@localhost ~]# df -h   # 能够看到快照和其对应的逻辑卷显示的参数值同样
...
/dev/mapper/myvg-mylv       489M   11M  453M   3% /data
/dev/mapper/myvg-mylv_snap  489M   11M  453M   3% /mnt
[root@localhost ~]# ls /mnt
inittab  lost+found
[root@localhost ~]# cp /etc/passwd /data   # 向原始卷中新增一些数据
[root@localhost ~]# ls /data
inittab  lost+found  passwd
[root@localhost ~]# ls /mnt   # 快照所显示的文件系统状态还是建立那一刻的
inittab  lost+found

LVM工做原理
--------------------------------------------------------------------------------------------------------------------------------------------------------
LVM在每一个物理卷头部都维护了一个metadata,每一个metadata中都包含了整个VG(volume group:卷组)的信息,包括每一个VG的布局配置,PV(physical volume:物理卷)的编号,LV(logical volume:逻辑卷)的编号,以及每一个PE(physical extends:物理扩展单元)到LE(logical extends:物理扩展单元)的映射关系。同一个VG中的每一个PV头部的信息都是相同的,这样有利于故障时进行数据恢复。

LVM对上层文件系统提供LV层,隐藏了操做细节。对文件系统而言,对LV的操做与原先对partition的操做没有差异。当对LV进行写入操做的时候,LVM定位相应的LE,经过PV头部的映射表将数据写入到相应的PE上。LVM实现的关LVM最大的特色就是能够对磁盘进行动态管理。由于逻辑卷的大小是能够动态调整的,并且不会丢失现有的数据。咱们若是新增长了硬盘,其也不会改变现有上层的逻辑卷。键在于PE和LE之间创建映射关系,不一样的映射规则决定了不一样的LVM存储模型。LVM支持多个PV 的stripe和mirror。

LVM最大的特色就是能够对磁盘进行动态管理,由于逻辑卷的大小是能够动态调整的,并且不会丢失现有的数据,若是咱们增长了硬盘也不会改变现有的上层逻辑卷。

LVM优缺点
--------------------------------------------------------------------------------------------------------------------------------------------------------
优势:
- 文件系统能够跨多个磁盘,所以文件系统大小不会受物理磁盘的限制。
- 能够在系统运行的状态下动态的扩展文件系统的大小。
- 能够增长新的磁盘到LVM的存储池中。
- 能够以镜像的方式冗余重要的数据到多个物理磁盘。
- 能够方便的导出整个卷组到另一台机器。

缺点:
- 在从卷组中移除一个磁盘的时候必须使用reducevg命令(这个命令要求root权限,而且不容许在快照卷组中使用)。
- 当卷组中的一个磁盘损坏时,整个卷组都会受到影响。
- 由于加入了额外的操做,存贮性能受到影响。

接下来,举出几个实例说明一下:
-------------------------------------------------------------------------------------------------------------------------------------------------------

1.准备物理分区(Physical Partions)
首先,咱们须要选择用于 LVM 的物理存储器。这些一般是标准分区,但也能够是已建立的 Linux Software RAID 卷。这里我利用fdisk命令,将sdb、sdc两块磁盘分了两个区sdb一、sdc1, 经过fdisk的t指令指定分区为8e类型(Linux LVM) ,以下图:

2.建立物理卷PV(Physical Volumes)
[root@cfbdb5 oracle]#pvcreate /dev/sdb1           //若是没有pvcreate、vgcreate等lvm命令,可使用yum install -y lvm2进行安装
Physical volume "/dev/sdb1" successfully created
[root@cfbdb5 oracle]# pvcreate /dev/sdc1           //能够直接使用pcvreate /dev/{sdb1,sdc1}
Physical volume "/dev/sdc1" successfully created

3.建立卷组VG(Volume Groups),命名为vg_test
[root@cfbdb5 ~]#vgcreate vg_test /dev/sdb1
Volume group "vg_test" successfully created
使用卷组查看命令vgdisplay显示卷组状况:
[root@cfbdb5 oracle]# vgdisplay
--- Volume group ---
VG Name vg_test
System ID
Format lvm2
Metadata Areas 1
Metadata Sequence No 6
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 1
Open LV 1
Max PV 0
Cur PV 1
Act PV 1
VG Size 19.99 GB
PE Size 4.00 MB
Total PE 5118
Alloc PE / Size 2560 / 10.00 GB
Free PE / Size 2558 / 9.99 GB
VG UUID YEYtOr-JpCK-P7MV-FFVo-BgEi-Ooef-IG3hlc

4.建立逻辑卷LV(Logical Volumes) ,命名为test_lv
建立逻辑卷的命令为lvcreate,-l 参数为定PE数来设定逻辑分区大小,也可使用-L参数直接指定逻辑分区大小,-n参数指定逻辑分区名称
[root@cfbdb5 oracle]# lvcreate -l 2000 -n lv_test vg_test
Logical volume "lv_test" created
也可使用-L参数
[root@cfbdb5 oracle]# lvcreate -L 10G -n lv_test vg_test
Rounding up size to full physical extent 19.99 GB
Logical volume "lv_test" created
使用lvdisplay命令查看逻辑卷状况:
[root@cfbdb5 oracle]#lvdisplay
--- Logical volume ---
LV Name /dev/vg_test/lv_test
VG Name vg_test
LV UUID kgUoMy-W1qG-7tAQ-dI5j-Z2KO-a8Td-mXAFbc
LV Write Access read/write
LV Status available
# open 0
LV Size 19.99 GB
Current LE 5118
Segments 1
Allocation inherit
Read ahead sectors auto
- currently set to 256
Block device 253:2

5.建立文件系统,并挂载
在逻辑卷上建立ext3文件系统:
[root@cfbdb5 oracle]#mkfs -t ext3 /dev/vg_test/lv_test             //能够直接使用mkfs.ext3或mkfs.ext4进行格式化,ext3或ext4是文件格式
[root@cfbdb5 oracle]#mount /dev/vg_test/lv_test /opt/oracle/
[root@cfbdb5 oracle]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/VolGroup00-LogVol00
16G 4.7G 11G 32% /
/dev/sda1 99M 27M 67M 29% /boot
tmpfs 872M 0 872M 0% /dev/shm
/dev/mapper/vg_test-lv_test
9.9G 151M 9.2G 2% /opt/oracle

LVM的最大好处就是能够动态地调整分区大小,而无须从新启动机器,下面让咱们来体验一下吧!
继续上面的实例,现假设逻辑卷/dev/vg_test/lv_test空间不足,须要增长其大小,咱们分两种状况讨论:
---------------------------------------------------------------------------------------------------------
1)卷组中有剩余的空间
经过vgdisplay命令能够检查当前卷组空间使用状况:

[root@cfbdb5 oracle]# vgdisplay
--- Volume group ---
VG Name vg_test
System ID
Format lvm2
Metadata Areas 1
Metadata Sequence No 6
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 1
Open LV 1
Max PV 0
Cur PV 1
Act PV 1
VG Size 19.99 GB
PE Size 4.00 MB
Total PE 5118
Alloc PE / Size 2560 / 10.00 GB
Free PE / Size 2558 / 9.99 GB
VG UUID YEYtOr-JpCK-P7MV-FFVo-BgEi-Ooef-IG3hlc
肯定当前卷组剩余空间9.99GB,剩余PE数量为2558个。在这里将全部的剩余空间所有增长给逻辑卷 /dev/vg_test/lv_test。
[root@cfbdb5 oracle]# lvextend -l +2558 /dev/vg_test/lv_test     //或者lvextend -L +9.99G /dev/vg_test/lv_test  
Extending logical volume lv_test to 19.99 GB
Logical volume lv_test successfully resized
也能够经过-L直接指定大小,经过 +/- 来 增长/减少 空间。
修改逻辑卷大小后,经过resize2fs来修改文件系统的大小。
[root@cfbdb5 oracle]#resize2fs /dev/vg_test/lv_test
resize2fs 1.39 (29-May-2006)
Filesystem at /dev/vg_test/lv_test is mounted on /opt/oracle; on-line resizing required
Performing an on-line resize of /dev/vg_test/lv_test to 5240832 (4k) blocks.
The filesystem on /dev/vg_test/lv_test is now 5240832 blocks long.
再次查看文件系统的大小:
[root@cfbdb5 oracle]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/VolGroup00-LogVol00
16G 4.7G 11G 32% /
/dev/sda1 99M 27M 67M 29% /boot
tmpfs 872M 0 872M 0% /dev/shm
/dev/mapper/vg_test-lv_test
20G 156M 19G 1% /opt/oracle

2)卷组中空间不足
  当卷组中没有足够的空间用于扩展逻辑卷的大小时,就须要增长卷组的容量,而增长卷组容量的唯一办法就是向卷组中添加新的物理卷。
  首先须要对新增长的磁盘进行分区、建立物理卷等工做。),接下来是利用vgextend命令将新的物理卷加入到卷组中, 咱们这里使用/dev/sdc1。
[root@cfbdb5 oracle]#vgextend vg_test /dev/sdc1
Volume group "vg_test" successfully extended
[root@cfbdb5 oracle]# vgdisplay
--- Volume group ---
VG Name vg_test
System ID
Format lvm2
Metadata Areas 2
Metadata Sequence No 8
VG Access read/write
VG Status resizable
MAX LV 0
Cur LV 1
Open LV 1
Max PV 0
Cur PV 2
Act PV 2
VG Size 59.98 GB
PE Size 4.00 MB
Total PE 15356
Alloc PE / Size 5118 / 19.99 GB
Free PE / Size 10238 / 39.99 GB
VG UUID YEYtOr-JpCK-P7MV-FFVo-BgEi-Ooef-IG3hlc

完成卷组的扩容后,就能够按照第一种状况的方法完成逻辑卷的扩容,最终实现分区的动态调整。如:
[root@cfbdb5 oracle]# lvextend -L +39G /dev/vg_test/lv_test
[root@cfbdb5 oracle]# resize2fs /dev/vg_test/lv_test
若是报错:
......
resize2fs: Bad magic number in super-block while trying to open /dev/vg_test/lv_test
Couldn't find valid filesystem superblock.

能够尝试用xfs命令
[root@docker-server ~]# xfs_growfs /dev/vg_test/lv_test

LVM的扩容需求操做也能够参考这篇文档(文档中间有这个操做记录):http://www.cnblogs.com/kevingrace/p/5822928.html

相关文章
相关标签/搜索