0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

软件RAID 5的实现过程详解

马哥Linux运维 来源:马哥Linux运维 2024-10-29 16:39 次阅读

软件raid 5的实现

RAID 5 是一种存储性能、数据安全和存储成本兼顾的存储解决方案。RAID 5可以理解为是RAID 0和RAID 1的折中方案。RAID 5可以为系统提供数据安全保障,但保障程度要比Mirror低而磁盘空间利用率要比Mirror高。RAID 5具有和RAID 0相近似的数据读取速度,只是多了一个奇偶校验信息,写入数据的速度比对单个磁盘进行写入操作稍慢。同时由于多个数据对应一个奇偶校验信息,RAID 5的磁盘空间利用率要比RAID 1高,存储成本相对较低,是目前运用较多的一种解决方案。

4d261aac-95a8-11ef-a511-92fbcf53809c.png

1 分区

这里使用/dev/sda8、/dev/sda9两分区和/dev/sdb、/dev/sdc两个硬盘。

注意:记得把分区的ID 改为fd

2创建raid 5

mdadm -C /dev/md5-a yes-l 5 -n 3 -x 1 /dev/sdd1/dev/sde1/dev/sdf/dev/sdb2

[root@centos7 ~]# mdadm -C /dev/md5 -a yes -l 5 -n 3 -x 1 /dev/sda8 /dev/sda9 /dev/sdb /dev/sdc
 
mdadm: Defaulting to version 1.2 metadata
mdadm: array /dev/md5 started.

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

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

-c CHUNK_SIZE:指明块大小

-x #:为指定备用磁盘个数,放在最后的默认为备用磁盘

3 创建文件系统

[root@centos7 ~]# mkfs.ext4 /dev/md5

4 挂载

(1)创建挂载目录

1 [root@centos7 ~]# mkdir /mnt/raid5

(2)挂载

1 [root@centos7 ~]# mount /dev/md5 /mnt/raid5

5 生成配置文件

[root@centos7 ~]# cat /etc/mdadm.conf
 
ARRAY /dev/md5 metadata=1.2 spares=1 name=centos7.3.loacl:5 UUID=5ec4115cff36d8a2:74f6fd8a

查看md的状态

[root@centos7 ~]# cat /proc/mdstat
 
Personalities : [raid0] [raid6] [raid5] [raid4]
md5 : active raid5 sdb[4] sdc[3](S) sda9[1] sda8[0]
2095104 blocks super 1.2 level 5, 512k chunk, algorithm 2 [3/3] [UUU]

查看raid的详细信息

[root@centos7 ~]# mdadm -D /dev/md5
 
/dev/md5:
Version : 1.2
Creation Time : Tue Apr 25 1454 2017
Raid Level : raid5
Array Size : 2095104 (2046.00 MiB 2145.39 MB)
Used Dev Size : 1047552 (1023.00 MiB 1072.69 MB)
Raid Devices : 3
Total Devices : 4
Persistence : Superblock is persistent
 
Update Time : Tue Apr 25 1408 2017
State : clean
Active Devices : 3
Working Devices : 4
Failed Devices : 0
Spare Devices : 1
 
Layout : left-symmetric
Chunk Size : 512K
 
Name : centos7.3.loacl:5 (local to host centos7.3.loacl)
UUID : 5ec4115cff36d8a2:74f6fd8a
Events : 18
 
Number Major Minor RaidDevice State
0 8 8 0 active sync /dev/sda8
1 8 9 1 active sync /dev/sda9
4 8 16 2 active sync /dev/sdb
 
3 8 32 - spare /dev/sdc

可以看到复合预期,三个活动设备,一个空闲(备用)设备

6 禁用和启用

umount /mnt/raid0
 
mdadm -S /dev/md0
 
mdadm -A /dev/md0

(1)停用raid

[root@centos7 ~]# umount /mnt/raid5
[root@centos7 ~]# mdadm -S /dev/md5
mdadm: stopped /dev/md5

检查一下,可以看到已经停止成功

[root@centos7 ~]# mdadm -D /dev/md5
 
mdadm: cannot open /dev/md5: No such file or directory

(2)启用raid设备

[root@centos7 ~]# mdadm -A /dev/md5
 
mdadm: /dev/md5 has been started with 3 drives and 1 spare.

再来检查一下,发现已经成功启动

[root@centos7 ~]# cat /proc/mdstat
 
Personalities : [raid0] [raid6] [raid5] [raid4]
md5 : active raid5 sda8[0] sdc[3](S) sdb[4] sda9[1]
2095104 blocks super 1.2 level 5, 512k chunk, algorithm 2 [3/3] [UUU]

7 模拟/dev/sdc损坏

[root@centos7 ~]# mdadm /dev/md5 -f /dev/sdc
 
mdadm: set /dev/sdc faulty in /dev/md5

8 移除/dev/sdc

[root@centos7 ~]# mdadm /dev/md5 -r /dev/sdc
mdadm: hot removed /dev/sdc from /dev/md5
 
[root@centos7 ~]# mdadm -D /dev/md5
 
/dev/md5:
[……]
Active Devices : 3
Working Devices : 3
Failed Devices : 0
Spare Devices : 0
[……]
Number Major Minor RaidDevice State
0 8 8 0 active sync /dev/sda8
1 8 9 1 active sync /dev/sda9
4 8 16 2 active sync /dev/sdb

可以看到已经移除成功。

再来看下磁盘情况

[root@centos7 ~]# lsblk
 
NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
fd0 2:0 1 4K 0 disk
sda 8:0 0 20G 0 disk
[……]
├─sda8 8:8 0 1G 0 part
│ └─md5 9:5 0 2G 0 raid5
└─sda9 8:9 0 1G 0 part
└─md5 9:5 0 2G 0 raid5
sdb 8:16 0 1G 0 disk
└─md5 9:5 0 2G 0 raid5
sdc 8:32 0 1G 0 disk
sr0 11:0 1 7.7G 0 rom

可以看到/dev/sdc已经不属于md5阵列

9添加到raid成员

[root@centos7 ~]# mdadm /dev/md5 -a /dev/sdc
 
mdadm:added/dev/sdc
[root@centos7 ~]# mdadm -D /dev/md5
 
/dev/md5:
[……]
Raid Devices : 3
Total Devices : 4
Active Devices : 3
Working Devices : 4
[……]
Number Major Minor RaidDevice State
0 8 8 0 active sync /dev/sda8
1 8 9 1 active sync /dev/sda9
4 8 16 2 active sync /dev/sdb
 
3 8 32 - spare /dev/sdc

可以看到添加成功

10 增加raid成员数量从3变为4个

这里添加设备/dev/sdd到阵列

[root@centos7 ~]# mdadm -G /dev/md5 -n 4 -a /dev/sdd
 
mdadm: added /dev/sdd
mdadm: Need to backup 3072K of critical section..

检查文件系统完整性

[root@centos7 ~]# e2fsck -f /dev/md5
 
e2fsck 1.42.9 (28-Dec-2013)
Pass 1: Checking inodes, blocks, and sizes
Pass 2: Checking directory structure
Pass 3: Checking directory connectivity
Pass 4: Checking reference counts
Pass 5: Checking group summary information
/dev/md5: 11/131072 files (0.0% non-contiguous), 17964/523776 blocks

同步文件系统

[root@centos7 ~]# resize2fs /dev/md5
 
resize2fs 1.42.9 (28-Dec-2013)
Resizing the filesystem on /dev/md5 to 785664 (4k) blocks.
The filesystem on /dev/md5 is now 785664 blocks long.

再来查看/dev/md5阵列情况

[root@centos7 ~]# mdadm -D /dev/md5
 
/dev/md5:
Version : 1.2
Creation Time : Tue Apr 25 1454 2017
Raid Level : raid5
Array Size : 3142656 (3.00 GiB 3.22 GB)
Used Dev Size : 1047552 (1023.00 MiB 1072.69 MB)
Raid Devices : 4
Total Devices : 5
Persistence : Superblock is persistent
 
Update Time : Tue Apr 25 1532 2017
State : clean
Active Devices : 4
Working Devices : 5
 
Failed Devices : 0
Spare Devices : 1
 
Layout : left-symmetric
Chunk Size : 512K
 
Name : centos7.3.loacl:5 (local to host centos7.3.loacl)
UUID : 5ec4115cff36d8a2:74f6fd8a
Events : 47
 
Number Major Minor RaidDevice State
0 8 8 0 active sync /dev/sda8
1 8 9 1 active sync /dev/sda9
4 8 16 2 active sync /dev/sdb
5 8 48 3 active sync /dev/sdd
 
3 8 32 - spare /dev/sdc

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 硬盘
    +关注

    关注

    3

    文章

    1282

    浏览量

    57188
  • 软件
    +关注

    关注

    69

    文章

    4682

    浏览量

    87066
  • RAID
    +关注

    关注

    0

    文章

    267

    浏览量

    35029
  • 磁盘
    +关注

    关注

    1

    文章

    359

    浏览量

    25152

原文标题:轻松搭建高可用存储!手把手教你实现软件 RAID 5!

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    RAID技术全程指南

    时更是如此。在同步镜像的进行过程中,外界对数据的访问不会受到影响,但是由于复制数据需要占用一部分的带宽,所以可能会使整个系统的性能有所下降。因为RAID 1主要是通过二次读写实现磁盘镜像,所以磁盘控制器
    发表于 03-30 11:48

    HiveSQL实现过程的原理详解

    HiveSQL解析过程详解
    发表于 06-04 16:27

    详解Linux RAID

    RAID(Redundant Array of Inexpensive Disks)称为廉价磁盘冗余阵列。RAID的基本想法是把多个便宜的小磁盘组合到一起,成为一个磁盘组,使性能达到或超过一个容量巨大、价格昂贵的磁盘。
    发表于 07-22 06:26

    RAID技术全解图解-RAID0、RAID1、RAID5RAID100【转载】精选资料分享

    图文并茂 RAID 技术全解 – RAID0、RAID1、RAID5RAID100……  RAID
    发表于 07-28 08:11

    (转载)RAID技术全解图解-RAID0、RAID1、RAID5RAID100 精选资料分享

    RAID技术全解图解-RAID0、RAID1、RAID5RAID100一、RAID 概述二、基
    发表于 07-28 09:25

    构建3-GBPS Esata/sata硬件RAID 5解决方

    构建3-GBPS Esata/sata硬件RAID 5解决方案:Xilinx FPGA 帮助 RAID 架构设计商Accusys 实现创新型 RAI
    发表于 04-25 10:34 20次下载

    什么是RAIDraid 1,raid 3 ,raid 5

    什么是RAID 5 数据及数据的奇偶校验信息分散存储在组成RAID 5的各个硬盘上。 RAID 5
    发表于 01-19 23:37 1659次阅读

    如何实现硬盘的raid

    如何实现硬盘的raid    问:最近在升级硬盘时听朋友说可以把两块硬盘做成RAID,请问RAID 是什么?要实现这个功能需要
    发表于 03-01 10:32 448次阅读

    RAID技术,RAID技术原理详细解说

    RAID技术,RAID技术原理详细解说 RAID入门基础及RAID0技术详解随着计算机应用的日益普及,人们对计算速度和性能的要求也逐
    发表于 03-29 09:56 836次阅读

    RAID5,RAID5工作原理是什么?

    RAID5,RAID5工作原理是什么? RAID 5 是一种存储性能、数据安全和存储成本兼顾的存储解决方案。 以四个硬盘组成
    发表于 03-29 10:09 4.8w次阅读

    RAID0,RAID1和RAID5是什么意思,其原理是什么

    RAID0,RAID1和RAID5是什么意思,其原理是什么 RAID 0:无差错控制的带区组 要实现R
    发表于 03-29 10:17 1.2w次阅读

    5RAID5中4块盘重建RAID5后恢复原RAID5数据的案例

    服务器数据恢复环境: 一台StorageWorks磁盘阵列设备,5块硬盘组建一组RAID5磁盘阵列。 服务器故障&分析: RAID5磁盘阵列中的一块硬盘掉线,由于RAID5
    的头像 发表于 09-27 15:02 2079次阅读

    硬盘Raid1 Raid2 Raid5 Raid6 Rraid10如何选择使用?

    今天浩道跟大家分享硬核干货,本文带大家盘点硬盘Raid1 Raid2 Raid5 Raid6 Rraid10如何选择使用!
    发表于 11-22 10:46 1806次阅读

    企业硬件RAID软件RAID

    电子发烧友网站提供《企业硬件RAID软件RAID.pdf》资料免费下载
    发表于 07-28 17:00 0次下载
    企业硬件<b class='flag-5'>RAID</b>和<b class='flag-5'>软件</b><b class='flag-5'>RAID</b>

    RAID5数据恢复—如何重组RAID5阵列?

    RAID5数据恢复环境: 一台存储上有一组由12块SCSI硬盘(11块数据盘+1块热备盘)组建的RAID5磁盘阵列,FreeBSD操作系统+zfs文件系统。 RAID5故障: 其中一块盘出现故障,需要重组该
    的头像 发表于 10-22 15:48 125次阅读
    <b class='flag-5'>RAID5</b>数据恢复—如何重组<b class='flag-5'>RAID5</b>阵列?