Linux RAID配置 和 LVM 分区配置

nas 协议 tcp/ip 用nfs,cifs等文件系统去管理

san 协议 光纤协议

raid redundant arrays of inexpensive disks

磁盘阵列

raid 0 读写性能佳,坏了其中一块,数据挂掉,可靠性低(stripe条带化),磁盘利用率100%

raid 1 镜像备份,同一份资料完整的保存在多个磁盘上,写的性能不佳,可靠性高,读的性能还行,磁盘利用率50%

raid 10 先做raid 1 再做raid 0

disk 0 disk 1 raid 1

disk 2 disk 3 raid 1

disk 4 disk 5 raid 1

然后把上面的三个raid1 做成raid0(条带)

raid 01 先做raid 0 再做raid 1 raid 0 raid 0

disk 0 disk 3

disk 1 disk 4

disk 2 disk 5

然后把上面的两个raid0 做成raid1

raid 10和 raid01就安全可靠性上来说还是raid10好点,读写性能一样,磁盘利用率一样

raid 5

由三块磁盘做raid 5,磁盘利用率为2/3, 另块放校验数据,允许坏一块盘,数据可以利用校验值来恢复

软raid

–raid 的创建用分区或者 虚拟机加磁盘来做

创建raid 0 [root@dns ~]# mdadm –create /dev/md0 –level=0 –raid-devices=2 /dev/sdb1 /dev/sdc1 mdadm: array /dev/md0 started.

创建过程中可以用另一终端cat /proc/mdstat 去查看正在创建的状态信息

[root@dns ~]# mkfs.ext3 /dev/md0 –把创建好的raid设备md0格式化成ext3[root@dns ~]# mount /dev/md0 /mnt/ –mount挂载使用

df -h查看大小验证磁盘利用率为百分之百

创建raid 5 [root@dns ~]# mdadm –create /dev/md1 –level=5 –raid-devices=3 /dev/sdd1 /dev/sde1 /dev/sdf1mdadm: array /dev/md1 started.

[root@dns ~]# mkfs.ext3 /dev/md1[root@dns ~]# mount /dev/md1 /media/

df -h查看大小验证磁盘利用率三分之二

—————————————————-raid的启停

[root@dns ~]# vim /etc/mdadm.conf –手动编写raid的配置文件,此文件不存在,要手动建立,并写上DEVICES /dev/sdb1 /dev/sdc1 /dev/sdd1 /dev/sde1 /dev/sdf1 –把做了raid的分区写上来

[root@dns ~]# mdadm –detail –scan >> /etc/mdadm.conf –扫描当前raid的信息,并追加到配置文件里

DEVICES /dev/sdb1 /dev/sdc1 /dev/sdd1 /dev/sde1 /dev/sdf1ARRAY /dev/md0 level=raid0 num-devices=2 metadata=0.90 UUID=80dfef62:8eef41dd:4f463d64:f1917614ARRAY /dev/md1 level=raid5 num-devices=3 metadata=0.90 UUID=3c416add:9fa78bcf:9b9e60ef:5f5de4da

停止raid设备

先umount 已经挂载的raid设备然后使用命令停止[root@dns ~]# mdadm –stop /dev/md0mdadm: stopped /dev/md0[root@dns ~]# mdadm –stop /dev/md1mdadm: stopped /dev/md1

启动raid设备 1,有/etc/mdadm.conf配置文件的情况下[root@dns ~]# mdadm -A /dev/md0 mdadm: /dev/md0 has been started with 2 drives.[root@dns ~]# mdadm -A /dev/md1mdadm: /dev/md1 has been started with 3 drives.

2,没有配置文件的情况下,手动把设备名写上就可以了[root@dns ~]# mdadm -A /dev/md0 /dev/sdb1 /dev/sdc1mdadm: /dev/md0 has been started with 2 drives.[root@dns ~]# mdadm -A /dev/md1 /dev/sdd1 /dev/sde1 /dev/sdf1mdadm: /dev/md1 has been started with 3 drives.

3,如果连设备名都不知道,可以去查看每个设备的raid信息,使用uuid把raid设备重新组合[root@dns ~]# mdadm -E /dev/sdf1/dev/sdf1: Magic : a92b4efc Version : 0.90.00 UUID : 3c416add:9fa78bcf:9b9e60ef:5f5de4da –这里可以看到uuid的值,同一个raid里的设备的uuid值是一样的Creation Time : Sat Jul 10 10:53:47 2010 Raid Level : raid5Used Dev Size : 1044096 (1019.80 MiB 1069.15 MB) Array Size : 2088192 (2039.59 MiB 2138.31 MB) Raid Devices : 3Total Devices : 3Preferred Minor : 1

Update Time : Sat Jul 10 11:06:17 2010 State : cleanActive Devices : 3Working Devices : 3Failed Devices : 0Spare Devices : 0 Checksum : 189291a1 – correct Events : 2

Layout : left-symmetric Chunk Size : 64K

Number Major Minor RaidDevice Statethis 2 8 81 2 active sync /dev/sdf1

0 0 8 49 0 active sync /dev/sdd1 1 1 8 65 1 active sync /dev/sde1 2 2 8 81 2 active sync /dev/sdf1

[root@dns ~]# mdadm -A –uuid=3c416add:9fa78bcf:9b9e60ef:5f5de4da /dev/md1mdadm: /dev/md1 has been started with 3 drives.

——————————————————–模拟raid中其中一块盘故障[root@dns ~]# mdadm /dev/md1 –fail /dev/sdd1mdadm: set /dev/sdd1 faulty in /dev/md1

[root@dns ~]# cat /proc/mdstat Personalities : [raid0] [raid6] [raid5] [raid4] md1 : active raid5 sdd1[3](F) sdf1[2] sde1[1] –可以看到sdd1后面有F标记 2088192 blocks level 5, 64k chunk, algorithm 2 [3/2] [_UU]

[root@dns ~]# mdadm /dev/md1 –remove /dev/sdd1 mdadm: hot removed /dev/sdd1

[root@dns ~]# mdadm /dev/md1 –add /dev/sdg1mdadm: added /dev/sdg1

–换了一块盘,此时也可以watch cat /proc/mdstat 去查看数据同步的状态,完成后,可以看到原来的数据还在

——————————————————–删除掉raid设备1,umount

2,[root@dns ~]# mdadm /dev/md0 –fail /dev/sdb1 –remove /dev/sdb1mdadm: set /dev/sdb1 faulty in /dev/md0mdadm: hot remove failed for /dev/sdb1: Device or resource busy[root@dns ~]# mdadm /dev/md0 –fail /dev/sdc1 –remove /dev/sdc1mdadm: set /dev/sdc1 faulty in /dev/md0mdadm: hot remove failed for /dev/sdc1: Device or resource busy

3,mdadm –stop /dev/md0

4,直接用fdisk删除分区或者用下面命令擦除superblock[root@dns ~]# mdadm –misc –zero-superblock /dev/sdb1 [root@dns ~]# mdadm –misc –zero-superblock /dev/sdc1

———————————————————————-

lvm logical volumn manager 逻辑卷管理

可以自由增大或者缩小卷空间的大小

pv physical volumn(物理卷) 把实际分区设备划为pv , pv是lvm物理标记

vg volumn group (卷组) 把pv划分成vg,相当于组合成lvm能够使用一个大硬盘

pe physical extend (物理扩展)vg组成的最小单位,默认是4M,vg最大支持65535个pe,相当于是block

lv logical volumn (逻辑卷) 实际可以使用的lvm的设备,相当是把vg划分成可用的分区

1,划分pv创建pv使用pvcreate命令[root@dns ~]# pvcreate /dev/sdb1Physical volume “/dev/sdb1” successfully created[root@dns ~]# pvcreate /dev/sdc1Physical volume “/dev/sdc1” successfully created[root@dns ~]# pvcreate /dev/md1Physical volume “/dev/md1” successfully created

查看相关信息的命令 pvscan pvdisplay

删除pv的命令 pvremove /dev/sdb1

2,划分vg

[root@dns ~]# vgcreate li /dev/md1 –创建一个叫li的vg,把/dev/md1加进去Volume group “li” successfully created

[root@dns ~]# vgextend li /dev/sdb1 –再入li这个vg增加pv,要用vgextendVolume group “li” successfully extended[root@dns ~]# vgextend li /dev/sdc1Volume group “li” successfully extended

查看相关信息的命令vgscan vgdisplay

[root@dns ~]# vgreduce li /dev/sdc1 –vgreduce跟vgextend是相反的,是在vg里移除pvRemoved “/dev/sdc1” from volume group “li”

移除vg的命令是vgremove,它是和vgcreate相反

3,创建lv

[root@dns ~]# lvcreate -L 500m -n li01 li –在li这个vg里划分出一个叫li01的lv,大小为500mLogical volume “li01” created[root@dns ~]# lvcreate -L 500M -n li02 liLogical volume “li02” created[root@dns ~]# lvcreate -l 125 -n li03 li — 小写l参数指定的是pe的个数,这里4M*125=500mLogical volume “li03” created[root@dns ~]# lvcreate -L 1g -n aa01 aaLogical volume “aa01” created

查看的相关参数为lvscan lvdisplay

[root@dns ~]# lvscan –创建后,可以看到这些实际可用的lv存放在/dev/vg名/lv名 ACTIVE ‘/dev/aa/aa01’ [1.00 GB] inheritACTIVE ‘/dev/li/li01’ [500.00 MB] inheritACTIVE ‘/dev/li/li02’ [500.00 MB] inheritACTIVE ‘/dev/li/li03’ [500.00 MB] inherit

[root@dns ~]# mkfs.ext3 /dev/aa/aa01 –格式化lv后就可以挂载使用

移除lv使用lvremove

完全删除lvm,就要先lvremove,再vgremove,最后pvremove

——————————–

lv的扩容

1,先考虑vg是否还有空间去扩容,如果没有,那么要先扩容vg,使用vgextend

2,扩lv[root@dns ~]# lvextend -L 1.5g /dev/aa/aa01 –把/dev/aa/aa01的lv扩成1.5gExtending logical volume aa01 to 1.50 GBLogical volume aa01 successfully resized

[root@dns ~]# df -hFilesystem Size Used Avail Use% Mounted on

/dev/mapper/aa-aa01 1008M 34M 924M 4% /mnt –查看已经挂载的大小,没有变化

[root@dns ~]# resize2fs /dev/aa/aa01 –再使用这个命令去在线同步resize2fs 1.39 (29-May-2006)Filesystem at /dev/aa/aa01 is mounted on /mnt; on-line resizing requiredPerforming an on-line resize of /dev/aa/aa01 to 393216 (4k) blocks.The filesystem on /dev/aa/aa01 is now 393216 blocks long.

[root@dns ~]# df -hFilesystem Size Used Avail Use% Mounted on

/dev/mapper/aa-aa01 1.5G 34M 1.4G 3% /mnt –再次查看,已经挂载的lv扩大了,并且数据没有影响

下面两种写法也可以[root@dns ~]# lvextend -L +100M /dev/aa/aa01 [root@dns ~]# lvextend -l +25 /dev/aa/aa01

lv的缩小

[root@dns ~]# resize2fs /dev/aa/aa01 1g –这样去缩小的话,报错已经mount了resize2fs 1.39 (29-May-2006)Filesystem at /dev/aa/aa01 is mounted on /mnt; on-line resizing requiredOn-line shrinking from 444416 to 262144 not supported.

[root@dns ~]# umount /mnt/

[root@dns ~]# resize2fs /dev/aa/aa01 1g –umount后再使用resize2fs命令,要求先去e2fsck检测resize2fs 1.39 (29-May-2006)Please run ‘e2fsck -f /dev/aa/aa01’ first.

[root@dns ~]# e2fsck -f /dev/aa/aa01

[root@dns ~]# resize2fs /dev/aa/aa01 1g –检测后再使用resize2fs命令缩小,并挂载查看大小是否缩小

实践题:建立一个raid5设备,并划分出一个lv,挂载到/www目录

使用apache建立两个虚拟主机,一个为,家目录为/www/www,由www用户使用ftp去管理文件,利用quota限制www用户使用空间为1G

另一个为web.linuxidc.com,家目录为/www/web,由web用户使用ftp去管理文件利用quota限制www用户使用空间为500m

注意权限问题,http运行时,rpm版是使用apache用户运行,它需要对网站根目录拥有执行权限去执行动态脚本,www,web这两个用户对各自管理的目录也应该拥有完全的上传,下载,删除权限

,带着感恩的心启程,学会爱,爱父母,爱自己,爱朋友,爱他人。

Linux RAID配置 和 LVM 分区配置

相关文章:

你感兴趣的文章:

标签云: