RAID:Redudant Arrays of Inexpensive(Independent) Disks    廉价(独立)冗余磁盘阵列

  提高IO能力:磁盘并行读写;

  提高耐用性:磁盘冗余来实现;

  级别:多块磁盘组织在一起的工作方式有所不同;

  RAID实现的方式:

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

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

    Sofeware RAID:

  级别:level

    RAID-0:0,条带卷,strip;

    RAID-1:1,镜像卷,mirror;

    RAID-2

    ...

    RAID-5:

    RAID-6

    RAID01

    RAID-0:

      读、写性能提升;

      可用空间:N*min(S1,S2,...)

      无容错能力

      最少磁盘数:2,2+

    RAID-1:

      读性能提升、写性能略有下降;

      可用空间:1*min(S1,S2,...)

      有冗余能力

      最少磁盘数:2

    RAID-4:

       1101,0110,1011

    RAID-5:

      读、写性能提升

      可用空间:(N-1)*min(S1,S2,...)

      有容错能力:1 块磁盘

      最少磁盘数:3,3+

    RAID-6:

      读、写性能提升

      可用空间:(N-2)*min(S1,S2,...)  

      有容错能力:2块磁盘

      最少磁盘数:4,4+

    混合类型:

    RAID-10:底层是1,上层为0

      读写性能提升;

      可用空间:N*min(S1,S2,...)/2

      有容错能力:每组镜像最多只能坏一块;

      最少磁盘数:4,4+      

    RAID-01:(不如10合理)

    JBOD:Just a Bunch of Disks

      功能:将多块磁盘的空间合并一个大的连续空间使用;

      可用空间:sum(S1,S2,...)

    常用级别:RAID-0,RAID-1,RAID-5,RAID-10,RAID-50,JBOD

    实现方式:

      硬件实现方式

      软件实现方式

      CentOS 6上的软件RAID的实现:

        结合内核中的md(multi devices)

        mdadm:模式化的工具

          命令的语法格式:mdadm [mode] <raiddevice> [options] <component-devices>

            支持的RAID级别:LINEAR,RAID0,RAID1,RAID4,RAID5,RAID6,RAID10;

          模式:

            创建:-C

            装配:-A

            监控:-F

            管理:-f,-r,-a

          <reaiddevice>:/dev/md#

          <componet-device>:任意块设备

          -C:创建模式

            -n #:使用#个块设备来创建此RAID;

            -l #:指明要创建的RAID的级别;

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

            -c CHUNK_SIZE:指明块大小;

            -x #:指明空闲盘的个数;

            例如:创建一个10G可用空间的RAID5;

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

            cat /proc/mdstat

            mdadm -D /dev/md0

            mdadm /dev/md0 -f /dev/sda7  将sda7标记为损坏

            watch -nl 'cat /pro/mdstat'

            mdadm /dev/md0 -r /dev/sda7  将sda7移除

          -D:显示raid的详细信息;

            mdadm -D /dev/md#

          管理模式:

            -f:标记指定磁盘为损坏;

            -a:添加磁盘;

            -r:移除磁盘

          观察md的状态:

            cat /proc/mdstat

          停止md设备:

            mdadm -S /dev/md#

        watch命令:

          -n #:刷新间隔,单位是秒;

          watch -n# 'COMMAND'

练习1:创建一个可用空间为10G的RAID1设备,要求其chunk大小为128k,文件系统为ext4,开机可自动挂载至/backup目录;

练习2:创建一个可用空间为10G的RAID10设备,要求其chunk大小为256k,文件系统为ext4,开机可自动挂载至/mydata目录;

LVM2:

  LVM:Logical Volume Manager,version:2

  dm:device mapper,将一个或多个底层块设备组织成一个逻辑设备的模块;  

          

Linux:Day8(下) RAID的更多相关文章

  1. 查看Linux系统下Raid信息

    软件raid:只能通过Linux系统本身来查看 cat /proc/mdstat 可以看到raid级别,状态等信息. 硬件raid: 最佳的办法是通过已安装的raid厂商的管理工具来查看,有cmdli ...

  2. 了解linux下RAID(磁盘阵列)创建和管理

    现在的操作系统,不论是windows 还是linux都具有raid的功能,RAID 分为硬件 RAID 和软件 RAID, 硬件 RAID 是通过 RAID 卡来实现的,软件RAID是通过软件实现的, ...

  3. linux基础-磁盘阵列(RAID)实例详解

    磁盘阵列(RAID)实例详解 raid技术分类 软raid技术 硬raid技术 Raid和lvm的区别 为什么选择用raid RAID详解 RAID-0 RAID-1 RAID-5 Raid-10 R ...

  4. 第7章 Linux上配置RAID

    7.1 RAID概念 RAID独立磁盘冗余阵列(Redundant Array of Independent Disks),RAID技术是将许多块硬盘设备组合成一个容量更大.更安全的硬盘组,可以将数据 ...

  5. 深入理解linux系统下proc文件系统内容

    深入理解linux系统下proc文件系统内容 内容摘要:Linux系统上的/proc目录是一种文件系统,即proc文件系统. Linux系统上的/proc目录是一种文件系统,即proc文件系统.与其它 ...

  6. LINUX中软RAID的实现方案

    转自linux就该这么学 应用场景 Raid大家都知道是冗余磁盘的意思(Redundant Arrays of Independent Disks,RAID),可以按业务系统的需要提供高可用性和冗余性 ...

  7. 在Linux虚拟机下配置tomcat

    1.到Apache官网下载tomcat http://tomcat.apache.org/download-80.cgi 博主我下载的是tomcat8 博主的jdk是1.8 如果你们的jdk是1.7或 ...

  8. 在Linux系统下运行微信Web开发者工具

    微信Web开发者工具只有window版本和mac版本,如果想要在Linux系统下运行微信Web开发者工具,需要花费很大周折. 注:带 * 的步骤或文件为不确定是否管用的步骤或文件.本人系统为Linux ...

  9. 在Linux虚拟机下配置jdk的环境变量

    1.到Oracle公司的官网里下载好jdk,网址 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133 ...

随机推荐

  1. mysql用户授权、数据库权限管理、sql语法详解

    mysql用户授权.数据库权限管理.sql语法详解 —— NiceCui 某个数据库所有的权限 ALL 后面+ PRIVILEGES SQL 某个数据库 特定的权限SQL mysql 授权语法 SQL ...

  2. 10个常见的JavaScript BUG

    译者按: 安全起见,在开发中我基本不用==. 原文: 10 COMMON JAVASCRIPT BUGS AND HOW TO AVOID THEM 译者: Fundebug 为了保证可读性,本文采用 ...

  3. K8S 部署 ingress-nginx (二) 部署后端为 tomcat

    在上面已经部署了 ingress-nginx, https://www.cnblogs.com/klvchen/p/9903480.html 创建 service 和 pods cd vi tomca ...

  4. angular 拼接html 事件无效

    主要是要引用$compile方法

  5. 有状态(Stateful)与无状态(Stateless)

    1.有状态(Stateful): 有数据存储功能.有状态对象(Stateful Bean),就是有实例变量的对象,可以保存数据,类里面有成员变量,而且成员变量是可变的,是非线程安全的.在不同方法调用间 ...

  6. js中判断空及获取当前服务的根路径

    function isValue(o) { return (this.isObject(o) || this.isString(o) || this.isNumber(o) || this.isBoo ...

  7. 我写的.net相关的文章

    此文正在更新中... 广州.net俱乐部相关 复活广州.net俱乐部 office365的开发者训练营,免费,在微软广州举办 被低估的.net(上) - 微软MonkeyFest 2018广州分享会活 ...

  8. LockSupport的源码实现原理以及应用

    一.为什么使用LockSupport类 如果只是LockSupport在使用起来比Object的wait/notify简单, 那还真没必要专门讲解下LockSupport.最主要的是灵活性. 上边的例 ...

  9. 作为IT,你的价值在哪里?

    也许最近是真的被无穷无尽的数据整理.导入.再整理.再导入给恶心到了. 业务部提交的数据只是一个非常初始的数据,IT还得在这个基础上七整八整,对导出的结果还要再做二次导入三次导入,不仅要帮业务部批导生成 ...

  10. Linux日志出现大量"kernel: NET: Registered protocol family 36"

    一台Linux服务器的系统错误日志出现大量的" kernel: NET: Registered protocol family 36"错误信息,如下所示: Jul  2 05:27 ...