RIAD配置
一、RAID磁盘阵列介绍
是Redundant Array of Independent Disks的缩写,中文简称为独立冗余磁盘阵列
把多块独立的物理硬盘按不同的方式组合起来形成一个硬盘组(逻辑硬盘),从而提供比单个硬盘更高的存储性能和提供数据备份技术
组成磁盘阵列的不同方式称为RAID级别(RAID Levels)常用的RAID级别
●RAID0,RAID1,RAID5,RAID6,RAID1+0等
RAID 0磁盘阵列介绍
■RAID 0(条带化存储)
- RAID 0连续以位或字节为单位分割数据,并行读/写于多个磁盘上,因此具有很高的数据传输率,但它没有数据冗余
- RAID 0只是单纯地提高性能,并没有为数据的可靠性提供保证,而且其中的一个磁盘失效将影响到所有数据
- RAID 0不能应用于数据安全性要求高的场合

RAID 1磁盘阵列介绍
■RAID 1(镜像存储)
- 通过磁盘数据镜像实现数据冗余,在成对的独立磁盘上产生互为备份的数据
- 当原始数据繁忙时,可直接从镜像拷贝中读取数据,因此RAID 1可以提高读取性能
- RAID 1是磁盘阵列中单位成本最高的,但提供了很高的数据安全性和可用性。当一个磁盘失效时,系统可以自动切换到镜像磁盘上读写,而不需要重组失效的数据

RAlD 5磁盘阵列介绍
TRAID 5
- N(N>=3)块盘组成阵列,一份数据产生N-1个条带,同时还有1份校验数据,共N份数据在N块盘上循环均衡存储
- N块盘同时读写,读性能很高,但由于有校验机制的问题,写性能相对不高
- (N-1)/N磁盘利用率
- 可靠性高,允许坏1块盘,不影响所有数据

RAID 6磁盘阵列介绍
RAID 6
- N(N>=4)块盘组成阵列,(N-2)/N磁盘利用率
- 与RAID 5相比,RAID 6增加了第二个独立的奇偶校验信息块
- 两个独立的奇偶系统使用不同的算法,即使两块磁盘同时失效也不会影响数据的使用
- 相对于RAID 5有更大的"写损

RAID 1+0磁盘阵列介绍
RAID 1+0(先做镜象,再做条带)
- N(偶数,N>=4)块盘两两镜像后,再组合成一个RAID 0
- N/2磁盘利用率
- N/2块盘同时写入,N块盘同时读取
- 性能高,可靠性高

RAID 0+1(先做条带,再做镜象)
- 读写性能与RAID 10相同
- 安全性低于RAID 10

| RIAD级别 | 硬盘数量 | 磁盘利用率 | 是否有校验 | 保护能力 | 写性能 |
| RIAD0 | N | N | 无 | 无 | 单个硬盘的N倍 |
| RIAD1 | N(偶数) | N/2 | 无 | 允许一个设备故障 | 需写两对存储设备,互为主备 |
| RIAD5 | N>=3 | N-1/N | 有 | 允许一个设备故障 | 需写计算校验 |
| RIAD6 | N>=4 | N-2/N | 有 | 允许两个设备故障 | 需双重写计算校验 |
| RIAD10 | N>=4(偶数) | N/2 | 无 | 允许两个基组中各坏一个 | N/2盘同时写入 |
二、阵列卡介绍
- 阵列卡是用来实现RAID功能的板卡
- 通常是由I/O处理器、硬盘控制器、硬盘连接器和缓存等一系列组件构成的
不同的RAlD卡支持的RAID功能不同
- 例如支持RAlD0、RAID1、RAID5、RAID10等
RAlD卡的接口类型
- IDE接口、SCSI接口、SATA接口和SAS接口
阵列卡的缓存
- 缓存(Cache)是RAID卡与外部总线交换数据的场所, RAID卡先将数据传送到缓存,再由缓存和外边数据总线交换数据
- 缓存的大小与速度是直接关系到RAID卡的实际传输速度的重要因素
- 不同的RAID卡出厂时配备的内存容量不同,一般为几兆到数百兆容量不等
三、案例举例:构建软RIAD磁盘阵列
需求描述:
●为Linux服务器添加4块SCSI硬盘
●使用mdadm软件包,构建RAID5磁盘阵列,提高磁盘存储的性能和可靠性
1、检查是否安装mdadm软件包
1 rpm -q mdadm 2 yum install -y mdadm 3 #
2、将添加的四块硬盘分区,分区类型的id号改为fd
fdisk /dev/sdb
fdisk /dev/sdc
fdisk /dev/sdd
fdisk /dev/sde
3、创建RIAD设备
#创建RIAD5
mdadm -C -v /dev/md0 [-a yes] -15 -n3 /dev/sd[bcd]1 -x1 /dev/ sde1
#创建 RAID10 ( 先做镜象,再做条带)
mdadm -Cv /dev/md0 - -l1 -n2 /dev/sd [bc] 1
mdadm -Cv /dev/md1 -l1 -n2 /dev/sd[de] 1
mdadm -Cv /dev/md10 -l0 -n2 /dev/md0 /dev/ md1
4、查看RIAD磁盘详细信息
cat /proc/ mdstat
#还能查看创建RAID的进度
或者
mdadm -D / dev/ md0 #用watch命令来每隔一段时间刷新/proc/mdstat的输出
watch -n 10 'cat /proc/mdstat’ #检查磁盘是否已做 RAID
mdaldm -E /dev/sd[b-e]1
5、创建并挂载文件系统
#创建文件系统
mkfs -t xfs /dev/ md0
#挂载文件系统
mkdir /data
mount /dev/md0 data/
df -Th
#设置开机自动挂载
vim /etc/ fstab
/dev/md0 /data xfs defaults 0 0
6、模拟故障恢复
mdadm /dev/md0 -f /dev/ sdb1
#模拟/dev/ sdb1故障
mdadm -D /dev/ md0
#查看发现sde1已顶替sdb1
7.创建 /etc/mdadm.conf 配置文件,方便管理软RAID的配置,比如启动、停止
echo ' DEVICE /dev/ sdc1 /dev/sdb1 /dev/ sdd1 /dev/sde1' > / etc/ mdadm. conf
mdadm --detail --scan>> / etc/ mdadm. conf
8、mdadm命令其它常用选项
-a: 添加设备
-S: 停止RAID
-A: 启动RAID
mdadm /dev/md0 -r /dev/ sdb1
mdadm /dev/md0 -a /dev/ sde1
echo ' DEVICE /dev/sdc1 /dev/sdb1 /dev/sdd1' > /etc/ mdadm. conf
mdadm --detail --scan >> /etc/mdadm. conf
umount /dev/md0
#启动之前要先解挂载
mdadm -S /dev /md0
mdadm -As /dev/ md0
#-s:指查找 /etc/mdadm. conf 文件中的配置信息
配置实战
1、添加四块硬盘

2、检测是否安装mdadm软件包

3、查看磁盘情况

4、划分区,四个磁盘步骤都一样

5、创建RIAD5

6、查看RIAD磁盘详细信息




7、创建并挂载文件系统


8、实现故障恢复


8.创建 /etc/mdadm.conf 配置文件,方便管理软RAID的配置,比如启动、停



RIAD配置的更多相关文章
- IBM X3650 M4服务器安装centos找不到硬盘的解决方法
IBM X3650 M4是IBM新的2U的服务器,IBM服务器以高稳定性和卓越的性能一直领先其他的服务器品牌成为全球第一.但是我们在用IBM的最新版9.4引导盘引导的时候,里面选项只有windows ...
- 实验:iscsi共享存储
实验名称: iscsi共享存储 实验环境: 我们需要准备一个磁盘,对于这个磁盘我们需要使用,将这个磁盘空间共享给iscsi客户端: 实验需求: 我们这里使用两台服务器来实现iscsi共享存储: 1.指 ...
- Dell做RAID配置图文全教程
首先准备工作:Dell服务器 首先重启Dell,我们会看到Dell服务器的启动页面: 当我们看到出现下面这个界面的时候,根据提示按下Ctrl+R进到SAS磁盘阵列里面 备注:大多数Dell服务器进磁盘 ...
- 配置android sdk 环境
1:下载adnroid sdk安装包 官方下载地址无法打开,没有vpn,使用下面这个地址下载,地址:http://www.android-studio.org/
- Android Studio配置 AndroidAnnotations——Hi_博客 Android App 开发笔记
以前用Eclicps 用习惯了现在 想学学 用Android Studio 两天的钻研终于 在我电脑上装了一个Android Studio 并完成了AndroidAnnotations 的配置. An ...
- react-router 组件式配置与对象式配置小区别
1. react-router 对象式配置 和 组件式配置 组件式配置(Redirect) ----对应---- 对象式配置(onEnter钩子) IndexRedirect -----对应-- ...
- 总结:Mac前端开发环境的搭建(配置)
新年新气象,在2016年的第一天,我入手了人生中第一台自己的电脑(大一时好友赠送的电脑在一次无意中烧坏了主板,此后便不断借用别人的或者网站的).macbook air,身上已无分文...接下来半年的房 ...
- Android Studio 多个编译环境配置 多渠道打包 APK输出配置
看完这篇你学到什么: 熟悉gradle的构建配置 熟悉代码构建环境的目录结构,你知道的不仅仅是只有src/main 开发.生成环境等等环境可以任意切换打包 多渠道打包 APK输出文件配置 需求 一般我 ...
- Virtual Box配置CentOS7网络(图文教程)
之前很多次安装CentOS7虚拟机,每次配置网络在网上找教程,今天总结一下,全图文配置,方便以后查看. Virtual Box可选的网络接入方式包括: NAT 网络地址转换模式(NAT,Network ...
随机推荐
- pytest框架fixture的使用
fixture可以当做参数传入 定义fixture跟定义普通函数差不多,唯一区别就是在函数上加个装饰器@pytest.fixture(),fixture命名不要以test开头,跟用例区分开.fixtu ...
- 十六进制转十进制 BASIC-12
十六进制转十进制 代码 import java.math.BigInteger; import java.util.Scanner; /* * 从键盘输入一个不超过8位的正的十六进制数字符串, * 将 ...
- rabbitMQ通过@RabbitListener和配置文件XML创建exchange及队列绑定关系
1.@RabbitListener 2.配置文件 <rabbit:fanout-exchange name="fanoutExchange" xmlns="http ...
- 1009 Product of Polynomials (25分) 晚上脑子就是容易僵住
#include<iostream> using namespace std; struct { int a; double b; }poly[1001]; double a[2001]; ...
- Java调用Zookeeper
watch机制 Zookeeper watch是一种监听通知机制,可以随时监听一些数据的变化,从而实现数据的及时性. Zookeeper所有的读操作getData(), getChildren()和 ...
- Redis奇怪的姿势
Redis奇怪的姿势 写在前面 之前渗透 摸鱼 时和小伙伴发现了一个redis,存在未授权,是win服务器但是没有路径,度娘了之后发现了这个姿势,特此学习记录一下. 写入启动项 环境搭建 window ...
- Nginx 真实的 IP
配置 Nginx 如果你的 Java 项目使用了 Nginx 代理,那么还需要进行以下配置,才能顺利获取到真实的 IP,否则只能获取到 127.0.0.1. 在 Nginx 的配置文件里,找到你 Ja ...
- com 组件的本知识
(今日看到网络上关于"COM中GUID......"文章,写的好,故记录之.)当初微软设计com规范的时候,有两种选择来保证用户的设计的com组件可以全球唯一:第一种是采用和Int ...
- 【axios】API 说明
基于promise用于浏览器和node.js的http客户端 特点 支持浏览器和node.js 支持promise 能拦截请求和响应 能转换请求和响应数据 能取消请求 自动转换JSON数据 浏览器端支 ...
- ABC类IP地址
A类IP地址一个A类IP地址由1字节的网络地址和3字节主机地址组成,网络地址的最高位 必须是"0", 地址范围从1.0.0.0 到126.0.0.0.可用的A类网络有126个,每个 ...