磁盘管理(二)Raid与LVM逻辑卷

概述:本章主要讲解raid和逻辑卷

什么是RAID

RAID:Redundant Arrays of Inexpensive(Independent) Disks

1988年由加利福尼亚大学伯克利分校( University ofCalifornia-Berkeley) “ A Case for RedundantArrays of Inexpensive Disks”。

多个磁盘合成一个“阵列”来提供更好的性能、冗余,或者两者都提供

RAID

提高IO能力:

          磁盘并行读写

提高耐用性;

          磁盘冗余来实现

级别:多块磁盘组织在一起的工作方式有所不同

RAID实现的方式:

        外接式磁盘阵列:通过扩展卡提供适配能力

        内接式RAID:主板集成RAID控制器

                    安装OS前在BIOS里配置

        Software RAID:通过OS实现

RAID级别:磁盘组织形式

                             

RAID-0:条带卷, strip

RAID-1: 镜像卷, mirror

RAID-2

..

RAID-5                    至少3块  相当于其中1块校验

RAID-6                    至少4块  相当于其中2块校验

RAID-10(RAID-1,RAID-0)

RAID-01(RAID-0,RAID-1)

   chunk

RAID-0:

读、写性能提升;

可用空间: N*min(S1,S2,…)(min为磁盘当中剩余空间最小的大小)

无容错能力

最少磁盘数: 2, 2+

一般用于非关键性数据例如临时文件、swap、中间交换数据

注重:不是说数据不重要就可以RAID-0,相关业务重要也不能用,例如web服务的缓存就不可以

RAID-1:

读性能提升(都可以读)、写性能略有下降(需要复制);

可用空间: 1*min(S1,S2,…)

有冗余能力

最少磁盘数: 2, 2N

RAID-4:

至少3块硬盘,其中一块存储校验码,其他存储数据

多块数据盘异或运算值,存于专用校验盘

有冗余能力(允许最多1块)

   RAID-5:

读、写性能提升

可用空间: (N-1)*min(S1,S2,…)

有容错能力:允许最多1块磁盘损坏

最少磁盘数: 3, 3+

RAID-6:

读、写性能提升

可用空间: (N-2)*min(S1,S2,…)

有容错能力:允许最多2块磁盘损坏

最少磁盘数: 4, 4+

RAID混合类型级别

RAID-10:(推荐使用的级别)

读、写性能提升

可用空间: N*min(S1,S2,…)/2

有容错能力:每组镜像最多只能坏一块

最少磁盘数: 4, 4+

RAID-01

  RAID-50(数据不关键,但是性能要求高使用可以还可以)

RAID7: 可以理解为一个独立存储计算机,自身带有操作系统和管理工具,可以独立运行,理论上性能最高的RAID模式

JBOD: Just a Bunch Of Disks

功能:将多块磁盘的空间合并一个大的连续空间使用

可用空间: sum(S1,S2,…)

常用级别: RAID-0, RAID-1, RAID-5, RAID-10,RAID-50, JBOD

软RAID

mdadm:为软RAID提供管理界面,为空余磁盘添加冗余

结合内核中的md(multi devices)

RAID设备可命名为/dev/md0、 /dev/md1、 /dev/md2、/dev/md3等等

软件RAID的实现

mdadm:模式化的工具

命令的语法格式: mdadm [mode] <raiddevice> [options] <component-devices>

支持的RAID级别: LINEAR(线性方式JBOD), RAID0, RAID1, RAID4,RAID5, RAID6, RAID10

模式:

        创建:-C

        装配: -A

        监控: -F

        管理:-f(模拟损坏), -r(移除), -a(增加)

        查询:-D

           <raiddevice>: /dev/md#

           <component-devices>: 任意块设备

        -C: 创建模式

            -n #: 使用#个块设备来创建此RAID;(此数量不包含冗余空闲盘数)

            -l #:指明要创建的RAID的级别;

            -a {yes|no}:自动创建目标RAID设备的设备文件;

            -c CHUNK_SIZE: 指明块大小;

            -x #: 指明冗余空闲盘的个数;

            例如:

                #mdadm -C /dev/md0 -a yes -n 3 -x 1 -l 5 /dev/sda{7,8,9,10}

        -D:显示raid的详细信息;

               mdadm -D /dev/md#

            观察md的状态:

               cat /proc/mdstat

            可以使用watch命令观测命令的执行过程

               watch -n1 'cat /proc/mdstat'   每过一秒刷新查看命令执行情况           

        管理模式:

              -f: 标记指定磁盘为损坏

                  例如:#mdadm -f /dev/md0 /dev/sda10

              -a: 添加磁盘(组内成员的重新添加)

                  例如:#mdadm /dev/md0 -a /dev/sda10

              -r: 移除磁盘

                  例如:#mdadm /dev/md0 -r /dev/sda10     

        停止md设备:

                  mdadm -S /dev/md#

软RAID配置实例

使用mdadm创建并定义RAID设备

      #mdadm -C /dev/md0 -a yes -l 5 -n 3 -x 1 /dev/sdb1 /dev/sdc1 /dev/sdd1 /dev/sde1

用文件系统对每个RAID设备进行格式化

      #mke2fs -j /dev/md0

测试RAID设备

 mdadm允许检查RAID设备的状况

      #mdadm –detail|D /dev/md0

增加新的成员

      #mdadm –G /dev/md0 –n4 -a /dev/sdf1

软RAID测试和修复

模拟磁盘故障

       #mdadm /dev/md0 -f /dev/sda1

移除磁盘

       #mdadm /dev/md0 –r /dev/sda1

从软件RAID磁盘修复磁盘故障

      替换出故障的磁盘然后开机

      在备用驱动器上重建分区

      #mdadm /dev/md0 -a /dev/sda1

mdadm、 /proc/mdstat及系统日志信息

软RAID管理

生成配置文件: mdadm –D –s >> /etc/mdadm.conf

停服务:     mdadm –S /dev/md0

激活:      mdadm –A –s /dev/md0 激活

强制启动:    mdadm –R /dev/md0

删除raid信息: mdadm –zero-superblock /dev/sdb1

逻辑卷管理器( LVM)

允许对卷进行方便操作的抽象层,包括重新设定

文件系统的大小

允许在多个物理设备间重新组织文件系统

    将设备指定为物理卷

    用一个或者多个物理卷来创建一个卷组

    物理卷是用固定大小的物理区域( Physical Extent,PE)来定义的

    在物理卷上创建的逻辑卷是由物理区域( PE)组成

    可以在逻辑卷上创建文件系统

 LVM: Logical Volume Manager, Version: 2

 dm: device mapper: 将一个或多个底层块设备组织成一个

     逻辑设备的模块

 设备名: /dev/dm-#

 软链接:

    /dev/mapper/VG_NAME-LV_NAME

        /dev/mapper/vol0-root

    /dev/VG_NAME/LV_NAME

        /dev/vol0/root

 LVM更改文件系统的容量

LVM可以弹性的更改LVM的容量通过交换PE来进行资料的转换,将原来LV内的PE转移到其他的设备中以降低LV的容量,或将其他设备中的PE加到LV中以加大容量

  删除逻辑卷

删除逻辑卷必须先删除LV,再删除VG,最后删除PV

pv

  

  pv管理工具

 显示pv信息

       pvs [ /dev/DEVICE ]:简要pv信息显示

       pvdisplay [ /dev/DEVICE ]:显示物理卷

 创建pv物理卷

       pvcreate /dev/DEVICE

    转移物理卷pe上的数据至别的pv上

       pvmove /dev/DEVICE 

    删除物理卷

       pvremove /dev/DEVICE 

    扫描物理卷

       pcscan

    检测物理卷

       pvck

  vg管理工具

 显示卷组

        vgs :简要vg信息显示

        vgdisplay 显示vg

 创建卷组

        vgcreate [-s #[kKmMgGtTpPeE]] VolumeGroupName PhysicalDevicePath [PhysicalDevicePath…]

                 -s:指定pe大小(默认4MiB)

        例如:vgcreate myvg /dev/sda3

 管理卷组

        vgextend VolumeGroupName PhysicalDevicePath [PhysicalDevicePath…] 卷组扩展

        例如:#vgextend myvg /dev/sda5

        vgreduce VolumeGroupName PhysicalDevicePath [PhysicalDevicePath…] 卷组缩减

        例如:#vgreduce myvg /dev/sda5

        vgsplit 卷组切割

        vgrename 卷组重命名

 删除卷组

         vgremove

        先做pvmove,再做vgremove

    扫描卷组

       vgscan

    检测卷组

       vgck

  lv管理工具

显示逻辑卷

        lvs 简要lv信息显示

        lvdisplay 显示lv

创建逻辑卷

        lvcreate -L #[mMgGtT] -n NAME VolumeGroup

        例如:lvcreate -L 5G -n lv0 myvg

删除逻辑卷

        lvremove /dev/VG_NAME/LV_NAME

    扫描逻辑卷

          lvscan

 

   扩展和缩减逻辑卷

   扩展逻辑卷:

           # lvextend -L [+]#[mMgGtT] /dev/VG_NAME/LV_NAME

           # resize2fs /dev/VG_NAME/LV_NAME

   缩减逻辑卷:

           # umount /dev/VG_NAME/LV_NAME

           # e2fsck -f /dev/VG_NAME/LV_NAME

           # resize2fs /dev/VG_NAME/LV_NAME #[mMgGtT]

           # lvreduce -L [-]#[mMgGtT] /dev/VG_NAME/LV_NAME

           # mount /dev/VG_NAME/LV_NAME MOUNT_POINT

      调整逻辑卷大小

          lvresize

     

重设文件系统大小

        fsadm [options] resize device [new_size[BKMGTEP]] 

        resize2fs [-f] [-F] [-M] [-P] [-p] device [new_size]

  创建逻辑卷实例

  fdisk /dev/sda

       n创建分区,t类型8e

创建物理卷

      pvcreate /dev/sda3

为卷组分配物理卷

      vgcreate vg0 /dev/sda3

从卷组创建逻辑卷

      lvcreate -L 256M -n data vg0

      mke2fs -j /dev/vg0/data

   mount /dev/vg0/data /mnt/data

逻辑卷管理器快照

快照是特殊的逻辑卷,它是在生成快照时存在的逻辑卷的准确拷贝

对于需要备份或者复制的现有数据集临时拷贝以及其它操作来说,快照是最合适的选择。

快照只有在它们和原来的逻辑卷不同时才会消耗空间。

   在生成快照时会分配给它一定的空间,但只有在原来的逻辑卷或者快照有所改变才会使用这些空间

   当原来的逻辑卷中有所改变时,会将旧的数据复制到快照中。

   快照中只含有原来的逻辑卷中更改的数据或者自生成快照后的快照中更改的数据

   建立快照的卷大小只需要原始逻辑卷的15%~20%就够了。也可以使用lvextend放大快照。

能够序列化的数据才能存储在磁盘上

逻辑卷管理器快照

快照就是将当时的系统信息记录下来,就好像照相一般,若将来有任何数据改动了,则原始数据会被移动到快照区,没有改动的区域则由快照区和文件系统共享。

   由于快照区与原本的LV共用很多PE的区块,因此快照去与被快照的LV必须要要在同一个VG上!系统恢复的时候的文件数量不能高于快照区的实际容量。

使用LVM快照

为现有逻辑卷创建快照

          #lvcreate -L #[mMgGtT] -s -n snap-data -p r original_lv_name

挂载快照

          #mkdir -p /mnt/snap

          #mount -o ro /dev/vg0/snap-data /mnt/snap

   删除快照

          #umount /mnt/databackup

          #lvremove /dev/vg0/databackup

1、创建一个至少有两个PV组成的大小为20G的名为testvg的VG;要求PE大小为16MB, 而后在卷组中创建大小为5G的逻辑卷testlv;挂载至/users目录

2、 新建用户archlinux,要求其家目录为/users/archlinux,而后su切换至archlinux用户,复制/etc/pam.d目录至自己的家目录

3、扩展testlv至7G,要求archlinux用户的文件不能丢失

4、收缩testlv至3G,要求archlinux用户的文件不能丢失

5、对testlv创建快照,并尝试基于快照备份数据,验正快照的功能

一、作业:

1:创建一个可用空间为1G的RAID1设备,文件系统为ext4,有一个空闲盘,开机可自动挂载至/backup目录

[root@localhost ~]# lsblk
NAME   MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sda      8:0    0  200G  0 disk 
├─sda1   8:1    0  200M  0 part /boot
├─sda2   8:2    0  100G  0 part /
├─sda3   8:3    0    4G  0 part [SWAP]
├─sda4   8:4    0    1K  0 part 
└─sda5   8:5    0   20G  0 part /testdir
sdb      8:16   0  200G  0 disk 
sdc      8:32   0   20G  0 disk 
sdd      8:48   0   20G  0 disk 
sde      8:64   0   20G  0 disk 
sdf      8:80   0   20G  0 disk 
sr0     11:0    1  7.2G  0 rom  
[root@localhost ~]# fdisk /dev/sdc
欢迎使用 fdisk (util-linux 2.23.2)。

更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。


命令(输入 m 获取帮助):n
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p
分区号 (1-4,默认 1):1
起始 扇区 (2048-41943039,默认为 2048):
将使用默认值 2048
Last 扇区, +扇区 or +size{K,M,G} (2048-41943039,默认为 41943039):+1G
分区 1 已设置为 Linux 类型,大小设为 1 GiB

命令(输入 m 获取帮助):t
已选择分区 1
Hex 代码(输入 L 列出所有代码):fd
已将分区“Linux”的类型更改为“Linux raid autodetect”

命令(输入 m 获取帮助):w
The partition table has been altered!

Calling ioctl() to re-read partition table.
正在同步磁盘。
[root@localhost ~]# fdisk /dev/sdd
欢迎使用 fdisk (util-linux 2.23.2)。

更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。

Device does not contain a recognized partition table
使用磁盘标识符 0x4d64216a 创建新的 DOS 磁盘标签。

命令(输入 m 获取帮助):n
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p
分区号 (1-4,默认 1):1
起始 扇区 (2048-41943039,默认为 2048):
将使用默认值 2048
Last 扇区, +扇区 or +size{K,M,G} (2048-41943039,默认为 41943039):+1G
分区 1 已设置为 Linux 类型,大小设为 1 GiB

命令(输入 m 获取帮助):t
已选择分区 1
Hex 代码(输入 L 列出所有代码):fd
已将分区“Linux”的类型更改为“Linux raid autodetect”

命令(输入 m 获取帮助):w
The partition table has been altered!

Calling ioctl() to re-read partition table.
正在同步磁盘。
[root@localhost ~]# fdisk /dev/sde
欢迎使用 fdisk (util-linux 2.23.2)。

更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。


命令(输入 m 获取帮助):n  
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p
分区号 (1-4,默认 1):1
起始 扇区 (2048-41943039,默认为 2048):
将使用默认值 2048
Last 扇区, +扇区 or +size{K,M,G} (2048-41943039,默认为 41943039):+1G
分区 1 已设置为 Linux 类型,大小设为 1 GiB

命令(输入 m 获取帮助):t
已选择分区 1
Hex 代码(输入 L 列出所有代码):fd
已将分区“Linux”的类型更改为“Linux raid autodetect”

命令(输入 m 获取帮助):w
The partition table has been altered!

Calling ioctl() to re-read partition table.
正在同步磁盘。
[root@localhost ~]# mdadm -C /dev/md0 -a yes -l 1 -n 2 -x 1 /dev/sd{c,d,e}1
mdadm: /dev/sdc1 appears to contain an ext2fs file system
       size=5242880K  mtime=Thu Sep  1 01:06:56 2016
mdadm: Note: this array has metadata at the start and
    may not be suitable as a boot device.  If you plan to
    store '/boot' on this device please ensure that
    your boot-loader understands md/v1.x metadata, or use
    --metadata=0.90
Continue creating array? 
Continue creating array? (y/n) y
mdadm: Defaulting to version 1.2 metadata
mdadm: array /dev/md0 started.
[root@localhost ~]# mdadm -D /dev/md0
/dev/md0:
        Version : 1.2
  Creation Time : Fri Sep  2 08:54:13 2016
     Raid Level : raid1
     Array Size : 1047552 (1023.17 MiB 1072.69 MB)
  Used Dev Size : 1047552 (1023.17 MiB 1072.69 MB)
   Raid Devices : 2
  Total Devices : 3
    Persistence : Superblock is persistent

    Update Time : Fri Sep  2 08:54:18 2016
          State : clean 
 Active Devices : 2
Working Devices : 3
 Failed Devices : 0
  Spare Devices : 1

           Name : localhost.localdomain:0  (local to host localhost.localdomain)
           UUID : 66a8159b:6b4c91d2:0b38312f:10694816
         Events : 17

    Number   Major   Minor   RaidDevice State
       0       8       33        0      active sync   /dev/sdc1
       1       8       49        1      active sync   /dev/sdd1

       2       8       65        -      spare   /dev/sde1
[root@localhost ~]# mkfs.ext4 /dev/md0
mke2fs 1.42.9 (28-Dec-2013)
文件系统标签=
OS type: Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
65536 inodes, 261888 blocks
13094 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=268435456
8 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks: 
     32768, 98304, 163840, 229376

Allocating group tables: 完成                            
正在写入inode表: 完成                            
Creating journal (4096 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
[root@localhost ~]#  mdadm –D –s >> /etc/mdadm.conf
[root@localhost ~]# mkdir /backup
[root@localhost ~]# vim /etc/fstab

#
# /etc/fstab
# Created by anaconda on Tue Jul 26 04:42:29 2016
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=68200b07-fec2-4be9-95a7-79fba9e46abf /                       xfs     defaults        0 0
UUID=de6b3e61-2dd2-4699-82c2-cb20d4b3ea1f /boot                   xfs     defaults        0 0
UUID=b43f466d-a800-45b2-abb7-956252340786 /testdir                xfs     defaults        0 0
UUID=ee28f7a7-70a5-4f52-a3c2-887e1edf2bae swap                    swap    defaults        0 0
UUID="e1fbc519-a5d4-4993-bd0a-2b314a447d19"     /backup ext4 defaults   0       0

[root@localhost ~]# mount /dev/md0 /backup/
[root@localhost ~]# df -h
文件系统        容量  已用  可用 已用% 挂载点
/dev/sda2       100G  4.1G   96G    5% /
devtmpfs        899M     0  899M    0% /dev
tmpfs           913M   84K  913M    1% /dev/shm
tmpfs           913M  9.0M  904M    1% /run
tmpfs           913M     0  913M    0% /sys/fs/cgroup
/dev/sda5        20G   33M   20G    1% /testdir
/dev/sda1       197M  139M   59M   71% /boot
tmpfs           183M   20K  183M    1% /run/user/42
tmpfs           183M     0  183M    0% /run/user/0
/dev/md0        991M  2.6M  922M    1% /backup

2:创建由三块硬盘组成的可用空间为2G的RAID5设备,要求其chunk大小为256k,文件系统为ext4,开机可自动挂载至/mydata目录

[root@localhost ~]# lsblk
NAME   MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sda      8:0    0  200G  0 disk 
├─sda1   8:1    0  200M  0 part /boot
├─sda2   8:2    0  100G  0 part /
├─sda3   8:3    0    4G  0 part [SWAP]
├─sda4   8:4    0    1K  0 part 
└─sda5   8:5    0   20G  0 part /testdir
sdb      8:16   0  200G  0 disk 
sdc      8:32   0   20G  0 disk 
sdd      8:48   0   20G  0 disk 
sde      8:64   0   20G  0 disk 
sdf      8:80   0   20G  0 disk 
sr0     11:0    1  7.2G  0 rom  /run/media/root/CentOS 7 x86_64
[root@localhost ~]# fdisk /dev/sdc
欢迎使用 fdisk (util-linux 2.23.2)。

更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。


命令(输入 m 获取帮助):n
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p
分区号 (1-4,默认 1):
起始 扇区 (2048-41943039,默认为 2048):
将使用默认值 2048
Last 扇区, +扇区 or +size{K,M,G} (2048-41943039,默认为 41943039):+2G
分区 1 已设置为 Linux 类型,大小设为 2 GiB

命令(输入 m 获取帮助):t
已选择分区 1
Hex 代码(输入 L 列出所有代码):fd
已将分区“Linux”的类型更改为“Linux raid autodetect”

命令(输入 m 获取帮助):w
The partition table has been altered!

Calling ioctl() to re-read partition table.
正在同步磁盘。
[root@localhost ~]# fdisk /dev/sdd
欢迎使用 fdisk (util-linux 2.23.2)。

更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。


命令(输入 m 获取帮助):n
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p
分区号 (1-4,默认 1):
起始 扇区 (2048-41943039,默认为 2048):
将使用默认值 2048
Last 扇区, +扇区 or +size{K,M,G} (2048-41943039,默认为 41943039):+2G
分区 1 已设置为 Linux 类型,大小设为 2 GiB

命令(输入 m 获取帮助):t   
已选择分区 1
Hex 代码(输入 L 列出所有代码):fd
已将分区“Linux”的类型更改为“Linux raid autodetect”

命令(输入 m 获取帮助):w
The partition table has been altered!

Calling ioctl() to re-read partition table.
正在同步磁盘。
[root@localhost ~]# fdisk /dev/sde
欢迎使用 fdisk (util-linux 2.23.2)。

更改将停留在内存中,直到您决定将更改写入磁盘。
使用写入命令前请三思。


命令(输入 m 获取帮助):n
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p
分区号 (1-4,默认 1):
起始 扇区 (2048-41943039,默认为 2048):
将使用默认值 2048
Last 扇区, +扇区 or +size{K,M,G} (2048-41943039,默认为 41943039):+2G
分区 1 已设置为 Linux 类型,大小设为 2 GiB

命令(输入 m 获取帮助):t
已选择分区 1
Hex 代码(输入 L 列出所有代码):fd
已将分区“Linux”的类型更改为“Linux raid autodetect”

命令(输入 m 获取帮助):w
The partition table has been altered!

Calling ioctl() to re-read partition table.
正在同步磁盘。
[root@localhost ~]# mdadm -C /dev/md0 -a yes -n 3 -l 5 -c 256 /dev/sd{c,d,e}1
mdadm: /dev/sdc1 appears to contain an ext2fs file system
       size=5242880K  mtime=Thu Sep  1 01:06:56 2016
Continue creating array? y          
mdadm: Defaulting to version 1.2 metadata
mdadm: array /dev/md0 started.
[root@localhost ~]# mdadm -D /dev/md0
/dev/md0:
        Version : 1.2
  Creation Time : Fri Sep  2 19:30:55 2016
     Raid Level : raid5
     Array Size : 4190208 (4.00 GiB 4.29 GB)
  Used Dev Size : 2095104 (2046.34 MiB 2145.39 MB)
   Raid Devices : 3
  Total Devices : 3
    Persistence : Superblock is persistent

    Update Time : Fri Sep  2 19:31:20 2016
          State : clean 
 Active Devices : 3
Working Devices : 3
 Failed Devices : 0
  Spare Devices : 0

         Layout : left-symmetric
     Chunk Size : 256K

           Name : localhost.localdomain:0  (local to host localhost.localdomain)
           UUID : 27fbade1:fe212fbb:fcc95220:3f9832ac
         Events : 18

    Number   Major   Minor   RaidDevice State
       0       8       33        0      active sync   /dev/sdc1
       1       8       49        1      active sync   /dev/sdd1
       3       8       65        2      active sync   /dev/sde1
[root@localhost ~]# mkfs.ext4 /dev/md0
mke2fs 1.42.9 (28-Dec-2013)
文件系统标签=
OS type: Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=64 blocks, Stripe width=128 blocks
262144 inodes, 1047552 blocks
52377 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=1073741824
32 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks: 
	32768, 98304, 163840, 229376, 294912, 819200, 884736

Allocating group tables: 完成                            
正在写入inode表: 完成                            
Creating journal (16384 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
[root@localhost ~]# mdadm -D -s >> /etc/mdadm.conf
[root@localhost ~]# vim /etc/fstab

#
# /etc/fstab
# Created by anaconda on Tue Jul 26 04:42:29 2016
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=68200b07-fec2-4be9-95a7-79fba9e46abf /                       xfs     defaults        0 0
UUID=de6b3e61-2dd2-4699-82c2-cb20d4b3ea1f /boot                   xfs     defaults        0 0
UUID=b43f466d-a800-45b2-abb7-956252340786 /testdir                xfs     defaults        0 0
UUID=ee28f7a7-70a5-4f52-a3c2-887e1edf2bae swap                    swap    defaults        0 0
UUID="f3445f57-4cbd-45dc-9175-6f188f30a149"     /backup ext4 defaults   0       0 
[root@localhost ~]# mount /dev/md0 /backup/

3、创建和扩展逻辑卷

创建并检查pv

[root@localhost etc]# pvcreate /dev/sdc
WARNING: ext4 signature detected on /dev/sdc at offset 1080. Wipe it? [y/n]: y
  Wiping ext4 signature on /dev/sdc.
WARNING: dos signature detected on /dev/sdc at offset 510. Wipe it? [y/n]: y
  Wiping dos signature on /dev/sdc.
  Physical volume "/dev/sdc" successfully created
[root@localhost etc]# pvs
  PV         VG   Fmt  Attr PSize  PFree 
  /dev/sdc   vg0  lvm2 a--  20.00g 20.00g

创建并检查vg

[root@localhost etc]# vgcreate vg0 /dev/sdc
  Volume group "vg0" successfully created
[root@localhost etc]# vgs
  VG   #PV #LV #SN Attr   VSize  VFree 
  vg0    1   0   0 wz--n- 20.00g 20.00g

创建并检查lv

[root@localhost etc]# lvcreate -L 19G  -n lv0 vg0
WARNING: ext4 signature detected on /dev/vg0/lv0 at offset 1080. Wipe it? [y/n]: y
  Wiping ext4 signature on /dev/vg0/lv0.
  Logical volume "lv0" created.
[root@localhost etc]# lvs
  LV   VG   Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  lv0  vg0  -wi-a----- 19.00g

格式化逻辑卷为ext4文件系统并挂载使用

[root@localhost etc]# mkfs.ext4 /dev/vg0/lv0
mke2fs 1.42.9 (28-Dec-2013)
文件系统标签=
OS type: Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=0 blocks, Stripe width=0 blocks
1245184 inodes, 4980736 blocks
249036 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=2153775104
152 block groups
32768 blocks per group, 32768 fragments per group
8192 inodes per group
Superblock backups stored on blocks: 
	32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 
	4096000

Allocating group tables: 完成                            
正在写入inode表: 完成                            
Creating journal (32768 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
[root@localhost etc]# vim /etc/fstab
#
# /etc/fstab
# Created by anaconda on Tue Jul 26 04:42:29 2016
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=68200b07-fec2-4be9-95a7-79fba9e46abf /                       xfs     defaults        0 0
UUID=de6b3e61-2dd2-4699-82c2-cb20d4b3ea1f /boot                   xfs     defaults        0 0
UUID=b43f466d-a800-45b2-abb7-956252340786 /testdir                xfs     defaults        0 0
UUID=ee28f7a7-70a5-4f52-a3c2-887e1edf2bae swap                    swap    defaults        0 0
UUID="5371c2fd-288b-4094-b567-215a1787f88d"     /backup ext4 defaults   0       0  
[root@localhost etc]# mount /dev/vg0/lv0 /backup

扩展逻辑卷20G

首先卸载逻辑卷

因为vg0卷组内没有20G空间所以要添加新的pv

添加新的pv并检查

[root@localhost etc]# pvcreate /dev/sdd
WARNING: dos signature detected on /dev/sdd at offset 510. Wipe it? [y/n]: y
  Wiping dos signature on /dev/sdd.
  Physical volume "/dev/sdd" successfully created
[root@localhost etc]# pvs
  PV         VG   Fmt  Attr PSize  PFree   
  /dev/sdc   vg0  lvm2 a--  20.00g 1020.00m
  /dev/sdd        lvm2 ---  20.00g   20.00g

将新添加的pv加入到vg0内,扩展vg0

[root@localhost etc]# vgextend vg0 /dev/sdd
  Volume group "vg0" successfully extended
[root@localhost etc]# vgs
  VG   #PV #LV #SN Attr   VSize  VFree 
  vg0    2   1   0 wz--n- 39.99g 20.99g

扩展lv0

[root@localhost etc]# lvextend -L +19G /dev/vg0/lv0 
  Size of logical volume vg0/lv0 changed from 20.00 GiB (5120 extents) to 39.00 GiB (9984 extents).
  Logical volume lv0 successfully resized.
[root@localhost etc]# lvs
  LV   VG   Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  lv0  vg0  -wi-a----- 39.00g

扩展文件系统

[root@localhost etc]# e2fsck -f /dev/vg0/lv0 
e2fsck 1.42.9 (28-Dec-2013)
第一步: 检查inode,块,和大小
第二步: 检查目录结构
第3步: 检查目录连接性
Pass 4: Checking reference counts
第5步: 检查簇概要信息
/dev/vg0/lv0: 11/1245184 files (0.0% non-contiguous), 122210/4980736 blocks
[root@localhost etc]# resize2fs /dev/vg0/lv0
resize2fs 1.42.9 (28-Dec-2013)
Resizing the filesystem on /dev/vg0/lv0 to 10223616 (4k) blocks.
The filesystem on /dev/vg0/lv0 is now 10223616 blocks long.

[root@localhost etc]# lsblk
NAME      MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sda         8:0    0  200G  0 disk 
├─sda1      8:1    0  200M  0 part /boot
├─sda2      8:2    0  100G  0 part /
├─sda3      8:3    0    4G  0 part [SWAP]
├─sda4      8:4    0    1K  0 part 
└─sda5      8:5    0   20G  0 part /testdir
sdb         8:16   0  200G  0 disk 
sdc         8:32   0   20G  0 disk 
└─vg0-lv0 253:0    0   39G  0 lvm  
sdd         8:48   0   20G  0 disk 
└─vg0-lv0 253:0    0   39G  0 lvm  
sde         8:64   0   20G  0 disk 
sdf         8:80   0   20G  0 disk 
sr0        11:0    1  7.2G  0 rom  /run/media/root/CentOS 7 x86_64

重新挂载使用

[root@localhost etc]# mount /dev/vg0/lv0 /backup/

原创文章,作者:NameLess,如若转载,请注明出处:http://www.178linux.com/43020

(0)
NameLessNameLess
上一篇 2016-09-05
下一篇 2016-09-05

相关推荐

  • VIM Note

    vim总结: 模式:编辑模式 插入模式 末行模式 内置命令行接口 打开文件 vim +# 打开文件后直接处于文件的#行行首 +/PATTER 打开文件后直接处于第一个被PATTER匹配到行的行首 + 直接处于尾行行首 模式转换 编辑模式:默认模式,打开文件后处于编辑模式 编辑模式–>插入模式: i: insert 光标所在地方输入 a:append 在…

    Linux干货 2017-08-14
  • web 服务进阶 httpd配置成https

    web服务进阶 自建CA/https详解 一、SSL与https 1、引言 我们网上购物、网上订票,以及使用支付宝支付过程中都会在网上直接输入账号和密码。这些信息都是非常重要的,如何才能在输入的过程中,不被别人看见和窃取,就需要对你输入的信息进行加密处理。 早期的两主机通信之间是没有加解密程序,后来就在传输层与应用层之间加了一个SSL库,完成加密解密功能。 …

    Linux干货 2016-12-11
  • iptables实验1

    Iptables 实验1 基于状态放行telnet, ftp, ssh, http, samba, icmp等服务; (1) 对本机的ping请求每分钟不得超出20个; (2) 每客户端对本机的ssh的并发连接数不得超过3个; (3) 本机的telnet服务仅允许工作时间内访问; 本机IP地址192.168.42.113 下面我们先放行所有入站状态为ESTA…

    Linux干货 2016-10-24
  • Linux发行版介绍

    一,Linux是什么?      Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统…

    2016-10-29
  • Linux系统上的文件处理工具

    Linux系统上的文件处理工具 我们都知道在计算机中,存在大量的文件,这些文件中包含大量的信息。可是有些时候,为了工作的效率,我们在茫茫信息中提取出我们所需要的信息,这样的技能就显得尤为重要。Linux系统上为我我们提供了多种多样的文本处理工具,下面我们来简单说一下。 查看文件内容我们可以使用less命令,cat命令,more命令等等 cat cat [OP…

    Linux干货 2016-08-05
  • LVM

    LVM是 Logical Volume Manager(逻辑卷管理)的简写,它是Linux环境下对磁盘分区进行管理的一种机制,它由Heinz Mauelshagen在Linux 2.4内核上实现,目前最新版本为:稳定版1.0.5,开发版 1.1.0-rc2,以及LVM2开发版。Linux用户安装Linux操作系统时遇到的一个常见的难以决定的问题就是如何正确地…

    Linux干货 2016-12-17