您当前的位置: 首页 > 学无止境 > 心得笔记 网站首页心得笔记
马哥linux运维学习笔记-Raid及mdadm命令之二
发布时间:2018-07-29 17:41:13编辑:雪饮阅读()
ide与sata的关系
ide磁盘又称为ata磁盘,而sata则是ata磁盘的升级版
mdadm
该命令用于通过软件模拟来实现raid,可以将任何块设备做成raid,既然是任何块设备,那么也就是说无论是硬盘还是硬盘的一个分区都可以用来做成raid。
命令参数:
-C:创建模式
-l:级别
-n:设备个数
-a:{yes|no}是否自动为其创建设备文件
-c:chunk大小,通常是2^n,如128,256。默认为64k
管理模式
--add, --del
装配模式
-A
模拟一个raid0磁盘阵列
准备两个1G的文件类型id为fd的文件系统分区
我这里是/dev/sdb1和/dev/sdb2
创建raid0磁盘阵列
[root@localhost ~]# mdadm -C /dev/md0 -a yes -l 0 -n 2 /dev/sdb{1,2}
mdadm: /dev/sdb1 appears to contain an ext2fs file system
size=20964792K mtime=Sun Jul 15 04:04:30 2018
Continue creating array? (y/n) y
mdadm: Defaulting to version 1.2 metadata
mdadm: array /dev/md0 started.
查看当前操作系统中已启动的raid设备
[root@localhost ~]# cat /proc/mdstat
Personalities : [raid0]
md0 : active raid0 sdb2[1] sdb1[0]
2117632 blocks super 1.2 512k chunks
格式化raid
[root@localhost ~]# mke2fs -j /dev/md0
mke2fs 1.41.12 (17-May-2010)
文件系统标签=
操作系统:Linux
块大小=4096 (log=2)
分块大小=4096 (log=2)
Stride=128 blocks, Stripe width=256 blocks
132464 inodes, 529408 blocks
26470 blocks (5.00%) reserved for the super user
第一个数据块=0
Maximum filesystem blocks=545259520
17 block groups
32768 blocks per group, 32768 fragments per group
7792 inodes per group
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912
正在写入inode表: 完成
Creating journal (16384 blocks): 完成
Writing superblocks and filesystem accounting information: 完成
This filesystem will be automatically checked every 28 mounts or
180 days, whichever comes first. Use tune2fs -c or -i to override.
mke2fs -j就是格式化ext3,ext3相比ext2就是多了日志,-j就是加上日志的意思,其实就是ext3。
然后就可以进行挂载使用了
整体架构是同一磁盘不同分区,实际生产环境上最好不同磁盘,否则对于io性能优化并没有什么改善
模拟创建raid1磁盘阵列
准备3个2G类型id为fd的文件系统的磁盘分区准备创建raid1
注意:新增分区后使用最好!par刷新下分区表,!par命令是partprobe命令的简写。
使用partprobe重载分区也只能是对不同的硬盘才能及时生效。对于同一块硬盘,修改过分区信息后,必须重启系统才能使修改过的分区信息生效。
创建raid1磁盘阵列
这里只用了两个磁盘是为了让其中一个磁盘是闲置的
[root@localhost ~]# mdadm -C /dev/md1 -a yes -n 2 -l 1 /dev/sdb3 /dev/sdb5
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? y
mdadm: Defaulting to version 1.2 metadata
mdadm: array /dev/md1 started.
查看raid磁盘阵列(所有阵列)同步情况
[root@localhost ~]# cat /proc/mdstat
Personalities : [raid0] [raid1]
md1 : active raid1 sdb5[1] sdb3[0]
2102400 blocks super 1.2 [2/2] [UU]
md127 : active raid0 sdb1[0] sdb2[1]
2117632 blocks super 1.2 512k chunks
unused devices: <none>
-D查看指定raid的相关信息,等同于--detail
[root@localhost ~]# mdadm -D /dev/md1
/dev/md1:
Version : 1.2
Creation Time : Mon Jul 23 02:28:57 2018
Raid Level : raid1
Array Size : 2102400 (2.01 GiB 2.15 GB)
Used Dev Size : 2102400 (2.01 GiB 2.15 GB)
Raid Devices : 2
Total Devices : 2
Persistence : Superblock is persistent
Update Time : Mon Jul 23 02:29:07 2018
State : clean
Active Devices : 2
Working Devices : 2
Failed Devices : 0
Spare Devices : 0
Name : localhost:1 (local to host localhost)
UUID : bc0c336f:49295985:6e31afeb:fe40f41e
Events : 17
Number Major Minor RaidDevice State
0 8 19 0 active sync /dev/sdb3
1 8 21 1 active sync /dev/sdb5
模拟损坏
[root@localhost ~]# mdadm /dev/md1 -f /dev/sdb3
mdadm: set /dev/sdb3 faulty in /dev/md1
移除磁盘,移除掉刚才模拟损坏的磁盘
[root@localhost ~]# mdadm /dev/md1 -r /dev/sdb3
mdadm: hot removed /dev/sdb3 from /dev/md1
添加磁盘(必须和之前磁盘大小保持一致),以替补刚才模拟损坏的磁盘
[root@localhost ~]# mdadm /dev/md1 -a /dev/sdb6
mdadm: added /dev/sdb6
停止指定阵列
[root@localhost ~]# mdadm -S /dev/md1
mdadm: stopped /dev/md1
然后删除该阵列对应的设备文件即可,如
rm -rf /dev/md1
启动(装配)阵列,如果之前停止阵列后还把对应阵列文件也删除了,则无法正常启动或装配阵列
[root@localhost ~]# mdadm -A /dev/md1 /dev/sdb3 /dev/sdb5
mdadm: /dev/md1 has been started with 2 drives.
watch,watch命令可以周期性的执行指定命令,并以全屏方式显示结果,-n参数指定周期长度,单位是秒,默认值是2。结合该命令我们可以动态显示阵列情况。
watch 'cat /proc/mdstat'
当某个磁盘模拟坏掉,然后有新增一个磁盘造成了闲置盘则新磁盘同步好之后会自动顶替上去,结合上面的watch命令会观察出来的
通过配置文件实现自动装配,将当前raid信息保存至配置文件,以便以后进行装配
mdadm -D --scan > /etc/mdadm.conf
停止与装配
[root@localhost ~]# mdadm -S /dev/md1
mdadm: stopped /dev/md1
[root@localhost ~]# mdadm -A /dev/md1
mdadm: /dev/md1 has been started with 2 drives.
raid磁盘阵列性能优化
在-C创建的时候-c参数指定chunk大小,通常是2^n,默认为64k。
而默认磁盘块是4096,即4k
那么都是默认情况下一个chunk相当于16个磁盘块
而在磁盘阵列格式化时候有个-E参数,该参数有stride子参数和-b子参数
前者表示条带倍数,后者表示条带大小。
条带倍数是chunk除以磁盘块大小的商
格式化时指定条带倍数与块大小这样格式化出来的磁盘性能就会比较好,尤其是在非常繁忙的时候,对于镜像卷意义不大,对于0和5的阵列还是有一定的作用的,应该给他们指定chunk
mke2fs -j -E stride=16 -b 4096 /dev/md0
关键字词:linux,raid,mdadm