Linux中raid磁盘阵列

Linux中raid磁盘阵列,第1张

概述一.磁盘阵列(Redundant Arrays of Independent Disks,RAID) 有“独立磁盘构成的具有冗余能力的阵列”之意。     磁盘阵列是由很多价格较便宜的磁盘,以硬件(RAID卡)或软件(MDADM)形式组合成一个容量巨大的磁盘组,利用多个磁盘组合在一起,提升整个磁盘系统效能。利用这项技术,将数据切割成许多区段,分别存放在各个硬盘上。 磁盘阵列还能利用同位检查(Par

一.磁盘阵列(Redundant Arrays of Independent disks,RAID) 有“独立磁盘构成的具有冗余能力的阵列”之意。

    磁盘阵列是由很多价格较便宜的磁盘,以硬件(RAID卡)或软件(MDADM)形式组合成一个容量巨大的磁盘组,利用多个磁盘组合在一起,提升整个磁盘系统效能。利用这项技术,将数据切割成许多区段,分别存放在各个硬盘上。 磁盘阵列还能利用同位检查(Parity Check)的观念,在数组中任意一个硬盘故障时,仍可读出数据,在数据。
注:RAID可以预防数据丢失,但是它并不能完全保证你的数据不会丢失,所以使用RAID的同时还是注意备份重要的数据.

二.RAID创建方式

    RAID的创建有两种方式:软RAID(通过 *** 作系统软件来实现)和硬RAID(使用硬件阵列卡);了解raID1、raID5和raID10。不过随着云的高速发展,供应商一般可以把硬件问题解决掉。

三.RAID磁盘阵列特点

对磁盘高速存取(提速): RAID将普通硬盘组成一个磁盘阵列,在主机写入数据,RAID控制器把主机要写入的数据分解为多个数据块,然后并行写入磁盘阵列;主机读取数据时,RAID控制器并行读取分散在磁盘阵列中各个硬盘上的数据,把它们重新组合后提供给主机。由于采用并行读写 *** 作,从而提高了存储系统的存取速度。扩容。数据冗余
四.RAID类型

raID级别:raID 0 raID 1 raID5 raIDe 10 raID 01

 

RAID 0

0 :(stripe)条带模式,至少需要两块硬盘,每一份数据平均分成多份存储在多个磁盘 中,且都处于一个水平条带上

优点:读写速度提高,用了多少块盘就是多少倍 缺点:无冗余能力(也称容错能力) 空间利用率:多个磁盘的总和,100%

RAID 1

1:(mirror)镜像模式,磁盘数量需要2的倍数,两个磁盘中存储的数据完全一致,当一 个盘损坏时,数据依然可以进行读写

优点:有冗余能力

缺点:磁盘利用率 只有50%,写的速度下降

RAID 5

5:check code校验码模式,至少需要三块硬盘,每一次存储数据时,采用条带模式存 储到n-1数量的磁盘中,另外一个磁盘存放的是其他几个磁盘中的数据以某种加密方式之 后得出的加密数据,且每一次存储,存储加密数据的磁盘都是不断变化的,当其中任何 一个盘的数据损坏时,都可以通过加密方式和其余两块磁盘的数据来得知另外一个盘的 数据,具有较高的冗余能力

优点:读写速度快,有冗余能力

缺点:磁盘利用率为n-1/n,两个磁盘损坏时,数据将丢失

组合起来用RAID10

10:mirror+stripe模式,至少需要4快硬盘,先将两块硬盘组成RaID1,然后将两组 RaID1组合成RaID0,存储一分数据时,每一RaID1的组合存储的数据都是均分的,然后 RaID1组合再用mirror模式存储

优点:读写速度快,冗余能力强 

缺点:磁盘利用率为50%

 

 

组合起来用RAID01

RAID01 是先做条带化再作镜像,本质是对物理磁盘实现镜像

优点:读写速度快,冗余能力强 

缺点:磁盘利用率为50%,安全性能比10差

比较:

 

 

RAID10和RAID01的比较

    两者最重要的区别在于:RAID10的底层是镜像RAID1,而镜像就保证了当有一块硬盘比如A1损坏时,并不影响他的写功能,读性能可能稍微有所降低(大概降低1/8)。但是RAID01的底层是条带RAID0,而条带就导致了只要有一块硬盘比如左边的disk0中的A1损坏时,那么整个左边的RAID0就不能使用了,所以整个RAID01就变成了只有右边的RAID0可以使用了,也就是从RAID01变成了RAID0,读性能马上降低一般,写性能没有影响,可靠性变得最差。仅仅凭借这一点,我们就绝不应该使用RAID01,而应该选择RAID10

 

五.RAID命令

    命令:mdadm (需要下载)
    #功能:创建/管理/删除 磁盘阵列
    #语法格式:
    mdadm [模式] <磁盘阵列名称> [选项] <组成设备>
    #模式:

  assemble:将以前定义的某个阵列加入当前在用阵列。  create:创建一个新的阵列,每个设备具有超级块  manage: 管理阵列,比如增加或移除  misc:允许单独对阵列中的某个设备做 *** 作,比如抹去超级块或 终止在用的阵列。  follow or Monitor:监控磁盘阵列的状态  grow:改变磁盘阵列容量或阵列中的设备数目

  

    选项:
 

 -A:加入一个以前定义的阵列 -C:创建一个新的阵列 (重要) -D:打印一个或多个设备的详细信息 -E:打印设备上的超级块的内容 -h:帮助信息,用在以上选项后,则显示该选项信息 -v:显示细节 -b:较少的细节。用于-D和-E选项 -f,--force 强制执行 -c:指定配置文件,缺省为 /etc/mdadm.conf -s:扫描配置文件或 /proc/mdstat以搜寻丢失的信息。

  

    create 或 build 使用的选项:

 -c:指定块大小,单位 kb. 缺省为 64. -l,:设定RAID模式.(非常重要) -n=:指定阵列中可用设备数目。 -x :指定初始阵列的热备盘数目。 -a,--auto{=no,yes,md,mdp,part,p}{NN} :创建RAID同时是否创建设备。

  

例:使用sdb sdc 创建raID0
mdadm -C /dev/md0 -l 0 -n 2 /dev/sd{b,c}1
raID查看方法

cat /proc/mdstat       mdadm --detail /dev/mdXXX

  

删除raID (删除raID前需要卸载对应的挂载点)

mdadm --stop /dev/mdXXXX
总结

以上是内存溢出为你收集整理的Linux中raid磁盘阵列全部内容,希望文章能够帮你解决Linux中raid磁盘阵列所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/1022945.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-23
下一篇 2022-05-23

发表评论

登录后才能评论

评论列表(0条)

保存