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. Linux上Simplescalar/ARM的安装和运行文档

    本文是基于ARM的simplescalar在ubuntu下的安装说明 1.1 软件下载  *********************文件下载地址:http://yunpan.cn/cw2n7dAyfG ...

  2. es6 语法 (map、set和array 的对比)

    //数据结构对比 增查改删 { //map和array对比 let map = new Map(); let array = []; //增 map.set('t',1); array.push({t ...

  3. es6 语法 (let 和const)

    一.let 和const 1.let 只在自己声明的块作用域中有效: function test(){ let a = 'a'; var b = 'b'; for(let i =1;i<3;i+ ...

  4. jQuery与vue分别实现超级简单的绿色拖动验证码功能

    jquery的绿色拖动验证功能 在网上看到了一个这样的问题:那种像拖动滑块匹配图形的验证方式是怎么实现的?. 突然想到实现一个简单绿色拖动验证码的功能,在网上搜了下,有一个用jquery实现的该功能代 ...

  5. 纯CSS+HTML实现checkbox的思路与实例

    checkbox应该是一个比较常用的html功能了,不过浏览器自带的checkbox往往样式不怎么好看,而且不同浏览器效果也不一样.出于美化和统一视觉效果的需求,checkbox的自定义就被提出来了. ...

  6. Gson解析空字符串异常的处理

    面对一些不规范的json,我们的gson解析经常会抛出各种异常导致app崩溃,这里可以采取一些措施来避免. 我们期望在后台返回的json异常时,也能解析成功,空值对应的转换为默认值,如:newsId= ...

  7. leetcode-38.报数

    leetcode-38.报数 题意 报数序列是一个整数序列,按照其中的整数的顺序进行报数,得到下一个数.其前五项如下: 1. 1 2. 11 3. 21 4. 1211 5. 111221 1 被读作 ...

  8. git 代码服务器的网页版gitweb的搭建

    sudo apt-get install apache2 git-core gitwebsudo a2enmod rewrite #vi /etc/gitweb.conf $projectroot = ...

  9. iOS 10.3下解决Fiddler代理抓包ssl证书信任问题

    iPhone系统更新到iOS 10.3以后,设置fiddler代理抓包,会出现无法抓取https请求,app请求失败的问题 这是因为在iOS 10.3之前,当你将安装fiddler的自定义证书后,iO ...

  10. sublime text 3 优化配置

    目录 1. sublime text 3 模板插件 SublimeTmpl 配置 修改模板内容格式 修改快捷键 2. 设置sublime text的 TAB 为4个空格 3. 添加markdown支持 ...