RAID是一种存储机制,英文全名为“RedundantArrays of Inexpensive Disks”,即容错廉价磁盘阵列。RAID可以通过一些技术(硬件或者软件)将多个磁盘整合起来,不仅是一个存储,还具有数据保护、提高IO能力等功能。不同等级的RAID有不同的功能。常见的RAID级别为RAID-0,RAID-1、RAID-5、RAID-6AID 1+0、RAID 1+0

RAID的实现方式:软件RAID、硬件RAID

  硬件RAID:

    外接式磁盘阵列:例如通过扩展卡提供适配能力

    内接式RAID:主板集成RAID控制器

  软件RAID

chunk:每块组成RAID-0的磁盘,都会被分隔为固定大小的小区块即chunk。当一个文件要写入RAID是,依据小区块(chunk)的大小切割好,一次放入RAID中。

RAID-0(等量模式,stripe):

  最少磁盘数:2

  可用空间:N*min[s1,s2……]

  优点:提升IO能力,读写性能均有提高

  缺点:没有冗余,耐用性降低

  数据存储方式:此处以两块磁盘为例。当有一个20M大小的数据写入时,每个磁盘将会被分配10M的数据

    

RAID-1(mirror,镜像模式)

  最少磁盘数:2

  可用空间:min[s1,s2……]

  优点:

    提升IO能力,写性能没有提(甚至会降低)高,读性能提高。

         有冗余,耐用性提高

  缺点:可用空间减少,由于每份数据都要完整的保存到两块磁盘,容量几乎减少50%。

  数据存储方式:此处以两块磁盘为例。当有一个20M大小的数据写入时,每个磁盘将会被分配20M的相同数据。

    

RAID-10和RAID-01:RAID-0性能佳但是数据不安全,RAID-1数据安全但是性能不佳。所以可以将两者结合起来组成RAID-10和RAID-01。

  RAID-10:举例来说,先将;两块磁盘组成RAID-1,并且这样的设置共有两组,然后将这两组RAID-1组成RAID-0。

    最少磁盘数:4

    可用空间:N*min[s1,s2……]/2

    优点:

      提升IO能力,读写性能提高。

           有冗余,耐用性提高

    缺点:可用空间减少,由于每份数据都要完整的保存到两块磁盘,容量几乎减少50%。

    数据存储方式:此处以四块磁盘为例。A和B组成第一组RAID-1,C和D组成第二组RAID-1,然后这两组在组成RAID-0。当有一个40M大小的数据写入时,由于RAID-0的特性,每组RAID-1会写入20M数据。由于RAID-1的特性,每块磁盘会写入20M数据。

    

 

  RAID-01:先组成RAID-0在组成RAID-1。

RAID4

  最少磁盘数:3

  可用空间:(N-1)*min(s1,s2,23.......)

  优点:

    提升IO能力,读性能提高,写性能不一定增加,因为软RAID写入的数据还要经过计CPU算同位校验码(parity)

        有冗余,耐用性提高允许坏一块盘

    缺点:可用空间减少一块单独一块做校验盘容易成为系统瓶颈。

    数据存储方式:此处以3块磁盘为例。A、B、C三块磁盘中有一块存储其他两块盘的校验码(此处认定为C盘)。有40M数据写入时,A、B各存储20M,C用来存放A、B盘的校验码。

RAID-5:以三块盘为例,与RAID4基本相同,不同的是RAID5是三块盘轮流做校验盘

  最少磁盘数:3

  可用空间:(N-1)*min(s1,s2,23.......)

  优点:

    读写性能均提升。

    有冗余,耐用性提高,允许坏一块盘。

linux上软RAID的实现

  在centos上要实现软RAID,依赖于内核的md(multi model)模块。

  命令:mdadm(multi model admin)

  语法:mdadm   [model]  <raiddevice> [options] <component-devices>

    model:

      创建:-C

      装配:-A

      监控:-F

      管理:--manage

        -f(--fail):将raid中某块磁盘标记为出错状态

        -r(--remove):

        -a(--add):

    raiddevice:/dev/md#。指名要创建或者管理的RAID设备。

    component-devices:指明raid组成成员是哪些盘

  -C:创建模式

    -n#:使用#快设备创建RAID

    -L#:创建RAID的级别

    -c chunk_size:指名块大小默认64M

    -x #:指定空闲盘的个数

    -a {yes|no}:自动创建目标RAID设备的设备文件

    示例:创建一个RAID-5设备,三块磁盘做存储,一块空闲磁盘。 

      第一步查看磁盘状态,并创建新的分区如下图创建sda{5,6,7,8}四个分区

      

      将分区的类型更改为fd。上图中新建的四个分区System还是Linux,需要将其改为fd。

        

      重读磁盘分区表

        使用:partprobe命令即可

      查看系统是否已经存在md设备:cat   /proc/mdstat。可以看到并没有md设备。此步骤主要是查看主机是否曾经创建过md设备,一次确定本次创建的md设备名称

      

      创建RAID-5

        mdadm -C /dev/md0  -a yes -l 5 -n 3 -x 1 /dev/sda{6,7,8,9}

      

      初始化raid设备

        mke2fs -t ext4 /dev/md0

      挂载使用

        mount /dev/md0 /mydata

      

仿真RAID出错状态处理

  查看raid详细信息:mdadm  --detail /dev/md0

    

  将磁盘sda6标记为错误状态

    

  查看raid信息,可以看到有一个错误状态的磁盘,并且空闲磁盘自动加入到raid中

    

    

  将出错的磁盘删除并且加入新的磁盘/dev/sda10:mdadm --manage /dev/md0 -a /dev/sda10 -r /dev/mda6

    

关闭raid

    

linuxRAID(软)的更多相关文章

  1. Android性能优化之巧用软引用与弱引用优化内存使用

    前言: 从事Android开发的同学都知道移动设备的内存使用是非常敏感的话题,今天我们来看下如何使用软引用与弱引用来优化内存使用.下面来理解几个概念. 1.StrongReference(强引用) 强 ...

  2. Atitit.研发管理软件公司的软资产列表指南

    Atitit.研发管理软件公司的软资产列表指南 1. Isv模型下的软资产1 2. 实现层面implet1 3. 规范spec层1 4. 法则定律等val层的总结2 1. Isv模型下的软资产 Sof ...

  3. 【腾讯Bugly经验分享】程序员的成长离不开哪些软技能?

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57ce8068d4d44a246f72baf2 Dev Club 是一个交流移动 ...

  4. Android 弱引用和软引用

    软引用 和 弱引用 1.  SoftReference<T>:软引用-->当虚拟机内存不足时,将会回收它指向的对象:需要获取对象时,可以调用get方法. 2.  WeakRefere ...

  5. Android中点击隐藏软键盘最佳方法——Android开发之路4

    Android中点击隐藏软键盘最佳方法 实现功能:点击EditText,软键盘出现并且不会隐藏,点击或者触摸EditText以外的其他任何区域,软键盘被隐藏: 1.重写dispatchTouchEve ...

  6. Android之弹出/隐藏系统软键盘

    Android弹出/隐藏系统软键盘的代码如下: InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT ...

  7. 软工实践——github文件整理

    软工实践中,整理github上文件遇到的一些问题 先扔github链接Transcend/ActivityHelper 1.原来呢我们团队的github上的文件的安排十分凌乱,没有归档.把说明文档.源 ...

  8. tp5 model 中的软删除

    model中需use traits\model\SoftDelete; // 数据表中需添加一个 delete_time 字段保存删除时间 namespace app\index\model; use ...

  9. Oracle SQL的硬解析和软解析

    我们都知道在Oracle中每条SQL语句在执行之前都需要经过解析,这里面又分为软解析和硬解析.在Oracle中存在两种类型的SQL语句,一类为 DDL语句(数据定义语言),他们是从来不会共享使用的,也 ...

随机推荐

  1. 启动elasticsearch报错的几种原因及解决方法

    ERROR: [1] bootstrap checks failed [1]: max virtual memory areas vm.max_map_count [65530] is too low ...

  2. Excel在线预览(通过poi转html,含里面的图片)

    支持03和07excel转html,直接上代码 测试类 /** * 主方法 * @author asus * */ public class App2 { public static void mai ...

  3. 设计模式C++描述----01.单例(Singleton)模式

    一.概念 单例模式:其意图是保证一个类仅有一个实例,并提供一个访问它的全局访问点,该实例被所有程序模块共享. class CSingleton { //公有的静态方法,来获取该实例 public: s ...

  4. 第七篇 Flask实例化配置及Flask对象配置

    一.Flask对象的配置 Flask 是一个非常灵活且短小精干的web框架 , 那么灵活性从什么地方体现呢? 有一个神奇的东西叫 Flask配置 , 这个东西怎么用呢? 它能给我们带来怎么样的方便呢? ...

  5. Java面向对象的三大特征和五大原则

    Java面向对象的三大特征 封装 封装(Encapsulation)是指属性私有化,根据需要提供setter和getter方法来访问属性.即隐藏具体属性和实现细节,仅对外开放接口,控制程序中属性的访问 ...

  6. 明解C语言 入门篇 第三章答案

    练习3-1 #include <stdio.h> int main() { int x; int y; puts("请输入两个整数."); printf("整 ...

  7. [考试反思]0814NOIP模拟测试21

    前两名是外校的240.220.kx和skyh拿到了190的[暴力打满]的好成绩. 我第5是170分,然而160分就是第19了. 在前一晚上刚刚爆炸完毕后,心态格外平稳. 想想前一天晚上的挣扎: 啊啊啊 ...

  8. 和manacher有关的乱写

    当初学kmp hash的时候被教导manacher非常的鸡肋 今天因为一篇神奇的题解我忍不住颓废了两节课把它学了 思路,代码都比较好懂 虽然它不如各种自动机霸气,唯一的功能貌似就是$O(n)$求出所有 ...

  9. 深入理解C#第三版部分内容

     最近,粗略的读了<深入理解C#(第三版)>这本技术书,书中介绍了C#不同版本之间的不同以及新的功能. 现在将部分摘录的内容贴在下面,以备查阅. C#语言特性: 1.C#2.0 C#2的主 ...

  10. p4141(消失之物)

    题目描述 ftiasch 有 N 个物品, 体积分别是 W1, W2, …, WN. 由于她的疏忽, 第 i 个物品丢失了. “要使用剩下的 N – 1 物品装满容积为 x 的背包,有几种方法呢?” ...