磁盘管理(二)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)
上一篇 2016-09-05 08:48
下一篇 2016-09-05 08:49

相关推荐

  • week1

    一,计算机的组成 五大基本部件 运算器:  算术运算,逻辑运算等各种各样的运算的, 控制器:  控制总线的使用权限,内存寻址 控制权限访问是读还是写               寄存器,内部的存储器,都是用来存储数据的  加速和提高cpu性能   &…

    Linux干货 2016-10-28
  • N22-第五周作业-冥界之王

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;    [root@CentOS6 ~]# cat /boot/grub/grub.conf | grep -E  "^[[:space:]]{1,}"…

    Linux干货 2016-09-19
  • git

    1.1 Git的安装 1.1.1 版本 # cat /etc/redhat-release CentOS release 6.8 (Final) # uname -r 2.6.32-642.4.2.el6.x86_64 # uname -m x86_64 1.1.2 安装 可以直接通过源码安装。先从Git官网下载源码,然后解压,…

    Linux干货 2016-10-31
  • Centos7下的systemd管理

    systemd简介 Systemd是由红帽公司的一名叫做Lennart Poettering的员工开发,systemd是Linux系统中最新的初始化系统(init),它主要的设计目的是克服Sys V 固有的缺点,提高系统的启动速度,systemd和upstart是竞争对手,ubantu上使用的是upstart的启动方式,centos7上使用systemd替换…

    Linux干货 2016-09-23
  • Linux发行版的基础目录名称、命名法则及功能规定

    Linux发行版的基础目录名称、命名法则及功能规定 / 主层次的根,也是整个文件系统层次结构的根目录  /bin 存放系统的命令。  /boot 存放系统的启动文件,及其内核。  /dev 系统设备文件主目录。  /etc 系统主要配置文件主目录。  /home 普通用户家目录。  /lib 系统库…

    Linux干货 2016-10-31
  • 网络设备及工作

    集线器集线器又叫Hub,是一种多用于星形网络组织的中心设备。具备中继器放大信号的特点,集线器是一种半双工,同一时间只能接收或发送数据,不能同时既接受又发送数据,是冲突型设备,共享带宽,放大信号的同时放大噪声,不隔离广播,不能成环,不安全。 二层交换机二层交换机的工作原理能自学习构造MAC地址表,基于MAC地址表进行转发、划分冲突域,对MAC地址实现过滤等功能…

    Linux干货 2017-10-30