概述:本章主要讲解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