Linux系统中实现RAID卷详解

简介:

 在Linux系统中做RAID,磁盘阵列的设备可以是一块磁盘中的三个以上的分区,也可以是三块或以上的磁盘。本文主要以几块磁盘为例,来实现在RAID5

实验环境:

   系统中有一块磁盘sda,新添加6SCSI磁盘,分别为sdb,sdc,sdd,sde,sdf,sdg,其中4块作为磁盘阵列的设备,1块作为预备(spare)磁盘,还有1块留作备用(用于扩展RAID)

创建RAID5:

1.先查看一下系统中磁盘设备:fdisk -l

...显示结果省略

2.接下来开始创建RAID了,主要会应用到mdadm命令,使用此命令需要先安装RHEL6安装光盘中自带的mdadm包,如果没有安装,先进行安装。

创建RAID5,命令如下:

1
[root@svr /]# mdadm --create --auto=yes /dev/md0 --level= 5  --raid-devices= 4  --spare-devices= 1  /dev/sd[b-f]

参数说明:

--create             //表示要创建raid

--auto=yes /dev/md0  //新建立的软件磁盘阵列设备为md0md序号可以为0-9

--level=5            //磁盘阵列的等级,这里表示创建是的raid5

--raid-devices       //添加作为磁盘阵列用的磁盘的块数

--spare-devices      //添加作为预备(spare)磁盘的块数

/dev/sd[b-f]         //磁盘阵列所使用的设备,还可写成/dev/sdb /dev/sdc /dev/sdd /dev/sde /dev/sdf

另外这条命令也可以简写:

1
[root@svr /]#mdadm -C /dev/md0 -l5 -n4 -x1 /dev/sd[b-f]

3.查看RAID是否成功创建及是否正常运行,有两种方法(当磁盘容量越大时,磁盘阵列构建的时间越长,所以可能需要等待很长时间才能看到以下信息):

执行mdadm --detail/dev/md0 命令查看RAID的详细信息:

110353744.jpg

查看/proc/mdstat文件,可以比较简单明了的查看RAID创建和运行的情况:

1
[root@svr ~]#cat /proc/mdstat

S代表预备(spare)磁盘,4U代表正常,出现_表示不正常

确认新建的RAID设备

执行 mdadm  -Q /dev/md0  //-Q用来查询设备信息。

1
[root@svr ~]#mdadm  -Q /dev/md0

4.格式化并且挂载和使用创建的RAID

1
2
3
[root@svr ~]# mkfs.ext4 /dev/md0
[root@svr ~]# mkdir /raid5
[root@svr ~]# mount /dev/md0 /mnt/raid5

查看一下新挂的RAID是否可以使用

111248860.jpg

5.设置开机自动启动RAID以及自动挂载

先建立/etc/mdadm.conf这个配置文件

1
2
3
[root@svr ~]# mdadm --detail /dev/md0 |grep UUID > /etc/mdadm.conf
[root@svr ~]# vi/etc/mdadm.conf
ARRAY/dev/md0 UUID=d58ed27d:00ce5cf5:b26ed1e9:879d0805

然后再修改/etc/fstab文件,设置开机自动挂载:

1
2
[root@svr ~]# vi/etc/fstab
/dev/md0        /mnt/raid5      ext4        defaults        0  0

然后再修改/etc/fstab文件,设置开机自动挂载:

重启一下系统,就可以检查开机自动挂载有没有设置成功了!


扩容raid磁盘阵列:

显示磁盘阵列的组成情况,4个块设备组成,

1
[root@svr /]# cat /proc/mdstat

/dev/sdg增加进阵列/dev/md0

1
[root@svr /]#mdadm --add /dev/md0 /dev/sdg

raid5阵列/dev/md0修改为5个块设备:

1
[root@svr /]#mdadm --grow/dev/md0 -n5

再显示一下磁盘阵列的组成情况,现在/dev/md16个块设备组成,完成扩容,还需要7.7分钟。

1
[root@svr /]#cat /proc/mdstat

等待扩容完成.....

执行下列命令:

1
[root@svr /]#resize2fs -f /dev/md0

验证是否已经扩大容量:

1
[root@svr /]#df -hT


验证预备磁盘是否能正常工作:

   模拟RAID5中一块磁盘损坏,检验spare磁盘的功能(raid5中允许一块磁盘损坏,我们所设置的那1spare磁盘会立即替代损坏的磁盘,进行RAID的重建,保障数据的安全):

先查看一下/dev/md0当前的状态

1
2
[root@svr /]#mdadm --detail /dev/md0
[root@svr /]#cat /proc/mdstat

使用以下命令设置磁盘sdd成为出错状态

1
[root@svr ~]#mdadm --manage /dev/md0 --fail /dev/sdd

接下来再来查看一下/dev/md0当前的状态

1
2
[root@svr /]#mdadm --detail /dev/md0
[root@svr /]#cat /proc/mdstat

进入到RAID挂载的目录raid5目录下,发现raid还可以使用,说明预备磁盘工作正常。

1
2
3
[root@svr /]#cd /raid5
[root@svr /]#touch  1 .txt
[root@svr /]#


将出错的磁盘删除并加入新的磁盘

先删除损坏的磁盘sdd,命令如下:

1
[root@svr raid5]#mdadm --manage /dev/md0    --remove/dev/sdd

再添加一块新的磁盘作为spare磁盘,命令如下:

1
[root@svr raid5]#mdadm --manage /dev/md0 --add /dev/sdg

OK,再来执行以下命令查看一下:

1
[root@svr /]#mdadm  --detail /dev/md0


关闭软件RAID的方法:

当你不再需要已经设置的RAID的时候,可以用以下方法关闭RAID

1、卸载/dev/md0,并且删除或注释掉/etc/fstab文件中的配置:

1
2
3
[root@svr ~]#umount /dev/md0
[root@svr ~]#vi /etc/fstab
#/dev/md0        /mnt/raid5        ext4        defaults             00

2、注释掉或删除/etc/mdadm.conf中的设置

1
2
[root@svr ~]#vi /etc/mdadm.conf
#ARRAY /dev/md0 UUID=d58ed27d:00ce5cf5:b26ed1e9:879d0805

3、停止raid设备

1
[root@svr ~]#mdadm --stop/dev/md0

4)删除raid中的所有磁盘

1
[root@svr ~]#mdadm --misc --zero-superblock /dev/sd[b-f]

这时候raid中的磁盘就删除了,重启后也不会有raid了。


RAID0RAID1实同于RAID5

RAID0:并行读写数据(带区卷)

RAID1:镜像磁盘阵列(镜像卷)



本文转自yun5277 51CTO博客,原文链接:http://blog.51cto.com/dengqi/1294831,如需转载请自行联系原作者

相关文章
|
1月前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
200 78
|
8天前
|
缓存 安全 Linux
Linux系统查看操作系统版本信息、CPU信息、模块信息
在Linux系统中,常用命令可帮助用户查看操作系统版本、CPU信息和模块信息
57 23
|
1月前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
74 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
2月前
|
缓存 Java Linux
如何解决 Linux 系统中内存使用量耗尽的问题?
如何解决 Linux 系统中内存使用量耗尽的问题?
227 48
|
1月前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
108 13
|
2月前
|
Ubuntu Linux 网络安全
linux系统ubuntu中在命令行中打开图形界面的文件夹
在Ubuntu系统中,通过命令行打开图形界面的文件夹是一个高效且实用的操作。无论是使用Nautilus、Dolphin还是Thunar,都可以根据具体桌面环境选择合适的文件管理器。通过上述命令和方法,可以简化日常工作,提高效率。同时,解决权限问题和图形界面问题也能确保操作的顺利进行。掌握这些技巧,可以使Linux操作更加便捷和灵活。
71 3
|
1月前
|
Ubuntu Linux C++
Win10系统上直接使用linux子系统教程(仅需五步!超简单,快速上手)
本文介绍了如何在Windows 10上安装并使用Linux子系统。首先,通过应用商店安装Windows Terminal和Linux系统(如Ubuntu)。接着,在控制面板中启用“适用于Linux的Windows子系统”并重启电脑。最后,在Windows Terminal中选择安装的Linux系统即可开始使用。文中还提供了注意事项和进一步配置的链接。
47 0
|
2月前
|
Linux
在 Linux 系统中,`find` 命令
在 Linux 系统中,`find` 命令
48 1
|
2月前
|
网络协议 Linux 虚拟化
如何在 Linux 系统中查看进程的详细信息?
如何在 Linux 系统中查看进程的详细信息?
294 1
|
1月前
|
存储 Oracle 安全
服务器数据恢复—LINUX系统删除/格式化的数据恢复流程
Linux操作系统是世界上流行的操作系统之一,被广泛用于服务器、个人电脑、移动设备和嵌入式系统。Linux系统下数据被误删除或者误格式化的问题非常普遍。下面北亚企安数据恢复工程师简单聊一下基于linux的文件系统(EXT2/EXT3/EXT4/Reiserfs/Xfs) 下删除或者格式化的数据恢复流程和可行性。