RAID磁盘阵列的搭建(以raid0、raid1、raid5、raid10为例)
mdadm工具的使用
|
-C或--creat |
建立一个新阵列 |
-r |
移除设备 |
|
-A |
激活磁盘阵列 |
-l 或--level= |
设定磁盘阵列的级别 |
|
-D或--detail |
打印阵列设备的详细信息 |
-n或--raid-devices= |
指定阵列成员(分区/磁盘)的数量 |
|
-s或--scan |
扫描配置文件或/proc/mdstat得到阵列缺失信息 |
-x或--spare-devicds= |
指定阵列中备用盘的数量 |
|
-f |
将设备状态定为故障 |
-c或--chunk= |
设定阵列的块chunk大小 ,单位为KB |
|
-a或--add |
添加设备到阵列 |
-G或--grow |
改变阵列大小或形态 |
|
-v |
--verbose 显示详细信息 |
|
|
a. RAID0 的搭建步骤:RAID0就是条带化。
1. 添加两块硬盘 并查看。
ls /dec/sd*
2 检测是否配置raid:
mdadm -E /dev/sd[b-c]
3. 给两块磁盘进行分区。 fdisk /dev/sdb fdisk /dev/sdc 注意这个地方-t ,fd, 将分区类型设置为fd。
4. 创建raid0 : mdadm -C -v /dev/md0 -l 0 -n /dev/sdb1 /dev/sdc1
5. 检查raid0是否搭建成功:
cat /proc/mdstat.
md0 : active raid0 sdc1[1] sdb1[0]
41908224 blocks super 1.2 512k chunks
unused devices: <none>
6. 生成配置文件。 mdadm -Dsv > /etc/mdadm.conf.
ARRAY /dev/md0 level=raid0 num-devices=2 metadata=1.2 name=xiaolyu:0 UUID=b024dbae:1dc6321e:c9bbd987:c687bcc2
devices=/dev/sdb1,/dev/sdc1
7. 对创建的raid0进行分区, 并且给分区所有的空间。
fdisk /dev/md0
8. 对分区进行格式化 并挂载。
格式化: mkfs -t xfs /dev/md0p1
创建挂载点: mkdir /raid0
挂载: mount /dev/md0p1 /raid0.
9 设置开机自动挂载。
umount /raid0
vim /etc/fstab
tail -1 /etc/fstab
/dev/md0p1 /raid0 xfs defaults 0 0
10 . 使用raid0 .
cp -rf /mnt/Packages /raid0 .
du -sh /mnt/Packages
du -sh /raid0/Packages
-------------------------------------------------------------------------------------------------------------------
b. RAID1的搭建方法: RAID1 就是镜像化。
1. 添加两块硬盘 并查看。
ls /dec/sd*
2 检测是否配置raid:
mdadm -E /dev/sd[b-c]
3. 给两块磁盘进行分区。 fdisk /dev/sdb fdisk /dev/sdc 中间切换成fd。
4. 创建raid1 : mdadm -C -v /dev/md1 -l 1 -n /dev/sd[b-c]1
5. 检查raid1是否搭建成功:
cat /proc/mdstat.
md1 : active raid1 sdc1[1] sdb1[0]
41908224 blocks super 1.2 512k chunks
unused devices: <none>
6. 生成配置文件。 mdadm -Dsv > /etc/mdadm.conf.
ARRAY /dev/md1 level=raid1 num-devices=2 metadata=1.2 name=xiaolyu:1 UUID=7a4491ed:905f9a8c:c3b428ce:6259a532
devices=/dev/sdb1,/dev/sdc1
7. 对创建的raid0进行分区, 并且给分区所有的空间。
fdisk /dev/md1
8. 对分区进行格式化 并挂载。
格式化: mkfs -t xfs /dev/md1p1
创建挂载点: mkdir /raid1
挂载: mount /dev/md1p1 /raid1.
9 设置开机自动挂载。
umount /raid1
vim /etc/fstab
tail -1 /etc/fstab
/dev/md1p1 /raid1 xfs defaults 0 0
10 . df -h 验证
11 . 使用raid1 .
touch /raid1/test.txt
echo "hello world" >> /raid1/test.ttxt
cat /raid1/test.txt 。
--------------------------------------------------------------------------------------------------------------------------
C. raid5 的创建过程:
1. 添加5块硬盘并查看。
ls /dev/sd*
/dev/sda /dev/sdb /dev/sdc /dev/sdd /dev/sde /dev/sdf
2. 查看磁盘是否已经配置raid了。
mdadm -E /dev/sd[b-f]
如果没有检测到如何超级块,意味着没有配置raid。
3. 对新添加的5块硬盘进行分区,并将分区类型设置为fd.
fdisk /dev/sdb -t fd w
fdisk /dev/sdc -t fd w
fdisk /dev/sdd -t fd w
fdisk /dev/sde -t fd w
fdisk /dev/sdf -t fd w
4. 创建raid5 .
mdadm -C -v /dev/md5 -l 5 -n 4 -x 1 /dev/sd[b-f]
5. 查看阵列信息。
mdadm -D /de/md5.
mdadm -Dsv /dev/md5.
6. 格式化并挂载。
mkfs -t xfs -f /dev/md5
创建挂载点: mkdir /raid5.
挂载md5 : mount /dev/md5 /raid5
查看是否挂载成功: df -h | tail -l 或者 df -h .
查看md5文件系统的类型。blkid /dev/md5.
7. 创建测试文件。
touch /raid5/test.txt .
echo "hello world " >> /raid5/test.txt.
8 . 生成配置文件。
mdadm -Dsv > /etc/mdadm.conf.
9. 设置开机自动挂载:
umount /raid5.
echo " /dev/md5 /raid5 / xfs defaults 0 0 " >> /etc/fstab
mount -av
df-h 查看是否挂载成功。
10 . 查看raid5的状态。
cat /proc/mdstat
-----------------------------------------------------------------------------------------------------------------------
说明raid5,我有一块热备盘,所以当有一块磁盘损坏后,数据的读写也不受影响,而且还可以将这块坏的硬盘恢复。
模拟/dev/sdb1磁盘损坏。
cat /raid5/test.txt
hello world .
mdadm /dev/md5 -f /dev/sdb1
cat /raid5/test.txt
hello world
说明:坏一块磁盘时,读写数据不受影响。
2 . 修复并添加/dev/sdb1 .
mdadm --zero-superblock --force /dev/sdb1
umount /raid5
mdadm -S /dev/md5
mdadm -As
mdadm: /dev/md5 has been started with 3 drives (out of 4) and 1 rebuilding.
[root@xiaolyu ~]# mdadm /dev/md5 --add /dev/sdb1
mdadm: added /dev/sdb1
mdadm -D /dev/md5查看一下:ok成功了。
---------------------------------------------------------------------------------------------------------------
D:raid10的创建过程:
RAID 10 可以被称为1 + 0或0 +1。它将做镜像+条带两个工作。在 RAID 10 中首先做镜像然后做条带。
在 RAID 01 上首先做条带,然后做镜像。RAID 10 比 01 好。
1. 先做两个raid1 . 分别为md1 和md11.
2. 再用这两个raid1,做成开一个raid0. 即OK!
因为前面的raid0 和raid1 的创建过程比较详细,这里仅简要给出步骤:
1. 添加4块一样大小的硬盘并查看。 ls /dev/sd* | grep sd[b-e]
/dev/sdb /dev/sdc /dev/sdd /dev/sde.
2. 给四块硬盘分区,每一块都给出全部的空间。
fdisk /dev/sdb -t fd w
fdisk /dev/sdc -t fd w
fdisk /dev/sdd -t fd w
fdisk /dev/sde -t fd w
3. 创建两个raid1。
mdadm -C -v /dev/md1 -l 1 -n 2 /dev/sd[b-c]1
mdadm -C -v /dev/md11 -l 1 -n 2 /dev/sd[d-e]1
4. 创建raid0
mdadm -C -v /dev/md10 -l 0 -n 2 /dev/md1 /dev/md11
5. 查看raid0的状态。
cat /proc/mdstat .
6. 格式化 挂载
mkfs -t xfs -f /dev/md10
创建挂载点: /raid10
挂载: /dev/md10 /raid10
检测挂载是否成功。 df -h | grep /raid10
7, 设置开机自动挂载:
umount /raid10
在/etc/fstab 最后添加这样一行:
/dev/md10 /raid10 xfs defaults 0 0
mount -av
8. 生成配置文件。
mdadm -Dsv >/etc/mdadm.conf
RAID磁盘阵列的搭建(以raid0、raid1、raid5、raid10为例)的更多相关文章
- 转 关于Raid0,Raid1,Raid5,Raid10的总结
关于Raid0,Raid1,Raid5,Raid10的总结 RAID0 定义: RAID 0又称为Stripe或Striping,它代表了所有RAID级别中最高的存储性能.RAID 0提高存储性能 ...
- 关于Raid0,Raid1,Raid5,Raid10的总结
RAID0 定义: RAID 0又称为Stripe或Striping,它代表了所有RAID级别中最高的存储性能.RAID 0提高存储性能的原理是把连续的数据分散到多个磁盘上存取,这样,系统有数据请求就 ...
- 简述raid0,raid1,raid5,raid10 的工作原理及特点
RAID 0 支持1块盘到多块盘,容量是所有盘之和 RAID1 只支持2块盘,容量损失一块盘 RAID 5最少三块盘,不管硬盘数量多少,只损失一块容量 RAID 10最少4块盘,必须偶数硬盘,不管硬盘 ...
- raid0 raid1 raid5
关于Raid0,Raid1,Raid5,Raid10的总结 RAID0 定义: RAID 0又称为Stripe或Striping,它代表了所有RAID级别中最高的存储性能.RAID 0提高存储性能 ...
- RAID详解[RAID0/RAID1/RAID5]
RAID(Redundant Array of Independent Disk 独立冗余磁盘阵列)技术是加州大学伯克利分校1987年提出,最初是为了组合小的廉价磁盘来代替大的昂贵磁盘,同时希望磁盘失 ...
- IBM MR10i阵列卡配置Raid0/Raid1/Raid5(转)
RAID5配置: 其实RAID0/RAID1都基本一致,只是选择的类型不同. 1. 开机看到ctrl+h的提示按下相应的键,等ServerRaid 10-i卡初始化完成则进入WebBIOS 配置界面: ...
- 1-15-2-RAID10 企业级RAID磁盘阵列的搭建(RAID1、RAID5、RAID10)
RAID10的搭建: 有两种方法, 第一种:直接使用四块磁盘,创建级别为10的磁盘阵列 第二种:使用四块磁盘先创建两个RAID1,然后在用RAID1创建RAID0 第一步:添加五个磁盘到虚拟机 开机后 ...
- 1-15-2-RAID5 企业级RAID磁盘阵列的搭建(RAID1、RAID5、RAID10)
RAID5的搭建 第一步:添加四个磁盘,开机并检查(略过) 第二步:使用fdisk命令分别对四个磁盘进行分区,效果如下图: 第三步:使用mdadm命令创建RAID5磁盘阵列 [root@localho ...
- 1-15-2-RAID1 企业级RAID磁盘阵列的搭建(RAID1、RAID5、RAID10)
大纲: 1.创建RAID1 2.创建RAID5 3.创建RAID10 =============================== 1.创建RAID1 RAID1原理:需要两块或以上磁盘,可添加热备 ...
随机推荐
- 软将工程课设day9
UI设计demo2.0. 在昨日demo的基础上进行了优化. 撰写美工设计报告,个人报告
- nginx(3、负载均衡)
当业务系统需要配置集群时,会用到nginx的负载均衡功能.nginx提供如下几种: 1.轮询(默认):将不同的请求随机分配给配置的服务器,若出现宕机,则自动切换:轮询可配置weight值,即权重,权重 ...
- Expression Tree 扩展MVC中的 HtmlHelper 和 UrlHelper
表达式树是LINQ To everything 的基础,同时各种类库的Fluent API也 大量使用了Expression Tree.还记得我在不懂expression tree时,各种眼花缭乱的A ...
- SmartImageView
== public class SmartImageView extends ImageView { public SmartImageView(Context context) { super(co ...
- ReactMix框架,让你实现一套js代码,基于ReactNative在H5,App都能完美跑起来,Write Once,Run Anywhere
ReactNative框架推出已经有一段时间了,相信很多小伙伴都在尝试实现Write Once, Run Anywhere的梦想,比如淘宝的ReactWeb等等,但是这些框架都局限于因为ReactNa ...
- Windows Azure Virtual Machine (25) 使用SSH登录Azure Linux虚拟机
<Windows Azure Platform 系列文章目录> 本文介绍内容适合于Azure Global和Azure China 为什么使用SSH登录Azure Linux虚拟机? 我们 ...
- C#高级一
1.单例模式:又叫单件模式,属于创建型模式分类.实际上讲,一个对象只允许创建一个实例,并且提供了一个全局的访问点. (静态方法生命周期长,消亡时间短,GC不回收) ================= ...
- 解决服务器每次都要输入Enter PEM pass phrase
今天架设好Python的HTTPS云服务器, 发现每次连接都要Enter PEM pass phrase 把服务器端的key里面的key剥离掉就好了 openssl rsa -in server.ke ...
- DDD~领域事件中使用分布式事务
回到目录 对于一个聚合来说,它可能会被附加很多事件,这里我们叫它领域事务,因为一个聚会我们可以把它理解成一个领域,一个业务.对于领域事件不清楚的同学可以看看我的这篇文章<DDD~领域事件与事件总 ...
- EF架构~为导航属性赋值时ToList()的替换方案
回到目录 今天在进行EF开发时,遇到一个问题,在进行join查询时,类中的一个集合类型的导航属性,在给它赋值时,将查询出来的结果ToList()后,出错了,linq to entity不支持这种操作, ...