推荐-常用RAID级别详解

一、RAID是什么

      RAID(Redundant Arrays of Indent Disks)的名称是独立磁盘冗余阵列,是一种通过将多块硬盘按照某种特定的结构组织起来当做一块硬盘来使用的技术,多块硬盘不同的组织结构我们称之为RAID的级别。而RAID技术的特性主要表现在两个方面:

(1)提高硬盘的IO能力,也就是提高硬盘的读写速率;

(2)提高硬盘的耐用性。

二、RAID的级别

   (1) RAID-0

    RAID-0也叫条带卷(strip),通过将多块硬盘并行的组织起来的磁盘组织结构,当我们有要存的数据时,首先是将数据流提交给控制器,控制器将数据流切割成多块数据(chunk)然后平均分散到磁盘中。加入我们现在有一个10GB大小的数据,在我们对硬盘做RAID-0后,我们每个硬盘只需要吞吐5GB的数据,所以提高了总体硬盘的IO能力。但这种方式的缺陷也很明显,我们将两块硬盘组织成一块硬盘后,如果其中一块硬盘损坏那我们的数据也就不能使用了。也就是是说RAID-0再提高了我们硬盘一个总体的IO能力的同时,也降低了总体硬盘的一个耐用性,所以我使用RAID-0方式组织的硬盘我们并不推荐存储重要的数据。

总结:(硬盘的数量为N)

(1)RAID-0提升了硬盘的读、写的速度;

(2)硬盘的可用空间:N*硬盘空间最小的那块硬盘的大小

(3)该结构没有容错能力

(4)最少磁盘数:2个(硬盘数量越多,读取速度越快,同时冗余性越差)

以下是RAID-0的结构图:

blob.png

   (2)RAID-1 

    RAID-1也叫镜像卷(mirror),是由两块硬盘所构成的存储阵列,当有需要存储的数据流时,数据流分别写入两块硬盘,当其中一块硬盘损坏时可以从另外一块硬盘读取数据,使用这种方式降低了数据的写入速度,因为要将数据写入两块硬盘,但是提升了数据的读取速度,因当两块硬盘中的数据是一样的,可以从两块硬盘中分别读取数据。同时也实现了数据的冗余性,当只坏其中一块硬盘时,数据可以从另一块硬盘中读出。但是这种方式也降低了硬盘的容量。当只有两块硬盘时,硬盘的容量仅为一半。

总结:

(1)RAID-1提升数据的读取速度,同时降低了数据的写入速度(数据写入速度最终取决于写入速度最慢的磁盘);

(2)硬盘的可用空间为1*硬盘空间最小的那块硬盘的大小

(3)该结构有冗余能力

(4)最少磁盘数:2个或2个以上(磁盘数量越多数据的读取速度越快,同时冗余性越高,但在这里RAID-1只推荐使用两块硬盘)


RAID-1的结构组织如下图所示:

 blob.png

    

     (3)RAID-4

    RAID-4使用三块或者以上的硬盘组织成RAID,其中一块做校验盘无语的盘用于存储数据。比如当前有三块硬盘做RAID-4时,其中一块磁盘作校验盘,其余两块磁盘用于存储数据。当有数据需要存储时,第一步仍然是将数据切成chunk然后将数据平均分入除校验盘以外的两块磁盘中,同时这两块磁盘中的数据做异或运算用来做校验码并将校验码存入校验盘中。当其中一块硬盘损坏时损坏磁盘的数据可以通过校验码计算出:例如

第一块硬盘的数据      第二块硬盘的数据      校验盘的数据

01110                11011             10101

   第一块硬盘损坏,第二块硬盘的数据和校验码做异或运算,结果为:01110 (也就是第一块硬盘的数据)  

总结:这种结构的磁盘有冗余性,但缺点是对校验盘的访问压力很大,所以校验盘有很大概率会损坏同时因为校验盘的IO的限制导致我们硬盘读取速率不高并且硬盘的损坏率也很高。

以下是RAID-4的结构:

blob.png

    (4)RAID-5

    RAID-5将校验码平均分到各个磁盘中,这样就将校验盘的访问压力平均分到每一块磁盘中降低了校验盘的访问压力。这种磁盘的结构既提升了IO同时磁盘又有冗余能力,同时根据第一块磁盘存放校验码还是最后一块磁盘存放校验码。如果将校验码当做对称线,那么使数据看上去可以分为左对称或右对称两种布局,左对称和右对称。两种布局方式的性能和使用机制不同,一般来讲RAID-5都是基于左对称

总结:(N为硬盘的个数)

(1)RAID-5提升了数据的读取速度和写入速度;

(2)硬盘的可用空间为N*硬盘空间最小的那块硬盘的大小

(3)该结构具有冗余能力(最多只能损坏一块硬盘)

(4)最少磁盘数:3个,或3个以上

   以下是RAID-5的结构:

blob.png

   (5)RAID-6

    只有当有4块以上的硬盘时才会使用RAID-6。RAID-6使用两块硬盘做校验盘,另外两块硬盘用于存储数据,同时两块校验盘做循环校验。硬盘使用这种结构组织既提升了IO能力同时也有冗余能力,只有两块硬盘都损坏的情况下,数据才会彻底损坏。

总结:(硬盘的数量为N)

(1)RAID-6的数据读取能力和数据的写入能力提升;

(2)硬盘的可用空间为:(N-2)*硬盘空间最小的那块硬盘的大小;

(3)该结构有冗余能力(最多允许两块硬盘损坏);

(4)最少磁盘数:4个或4个以上。


 以下是RAID-6的结构:

blob.png

    (6)RAID-10

     RAID-10就是先将硬盘两两一组做成RAID-1然后再将这一组一组的RAID-1做成RAID-0。而RAID-01就是先将硬盘两组硬盘,每一组的硬盘单独做成RAID-0然后这两组硬盘做成RAID-1。

RAID-10总结:(硬盘的数量为N)

(1)RAID-10的数据的读取能力和数据的写入能力提升;

(2)硬盘的可用空间:N*硬盘空间最小的那块硬盘的大小/2;

(3)该结构有冗余能力,每组镜像只能损坏一块硬盘;

(4)最少磁盘数:4个或者4个以上。

RAID-01总结:(硬盘的数量为N)

(1)RAID-01的数据读取能力和数据的写入能力提升;

(2)硬盘的可用空间:N*硬盘空间最小的那块硬盘的大小/2;

(3)该结构有冗余能力,可以损坏任意一组的硬盘;

(4)最少磁盘数:4个或者4个以上。


RAID-10的结构:

blob.png

RAID-01结构:

blob.png

原创文章,作者:因为有你,如若转载,请注明出处:http://www.178linux.com/12946

(1)
因为有你因为有你
上一篇 2016-03-27
下一篇 2016-03-27

相关推荐

  • 马哥教育网络班22期+第1周课程练习

    week1作业: 1.描述计算机的组成及其功能。    计算机的组成:    CPU:控制器、运算器、寄存器、CPU缓存(RAM,一级、二级、三级缓存)    控制器(Control):是整个计算机的中枢神经,其功能是对程序规 定的控制信息进行解释,根据其要求进行控制,…

    Linux干货 2016-08-15
  • Linux 第九天: Linux Shell脚本编程

    Linux 第九天: (08月11日) Linux Shell脚本编程     Shell脚本是包含一些命令或声明, 并符合一定格式的文本文件格式要求 运行shebang机制#!/bin/bash   bash -n /path/to/some_script  检测脚本中的语法错误bash -x /path/to/so…

    Linux干货 2016-08-15
  • linux 病毒 sfewfesfs

    由于昨天在内网服务器A不小心rm -fr / ,导致服务器A完蛋,重装系统后,不知道啥原因,局域网瘫痪不能上网,最后发现内网服务器A的一个进程sfewfesfs cpu 300%。路由器被网络阻塞啦。 于是百度这个病毒:都说该病毒很变态。第一次中linux病毒,幸亏是内网,感觉比较爽。(总结网络内容,引以为戒) 1、病毒现象 服务器不停向外网发送数据包,占网…

    Linux干货 2015-04-03
  • N25期第三周作业

    1.列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可 who|awk ‘{print $1}’|sort -u 2.取出最后登录到当前系统的用户的相关信息 last -1 3.取出当前系统上被用户当作其默认shell的最多的那个shell cat /etc/passwd|awk -F: ‘{print $NF}’|sort…

    Linux干货 2016-12-12
  • 第一篇文章

    第一篇文章。

    Linux干货 2016-12-26
  • btrfs管理和应用

    一、btrfs概念        在btrfs中存在三种类型的数据,data, metadata和system。它们表示:        DATA           数据块。       &nbsp…

    系统运维 2016-04-12

评论列表(1条)

  • stanley
    stanley 2016-03-27 21:58

    细节可以看的到差距,赞。图非常认真给力。赞