写在前面的话,研究下来,raid提供了数据保护的功能,比如raid1有两块硬盘互为镜像,一块盘坏了,系统可以正常运行。但是不代表着,拔下一块硬盘后,系统可以正常启动。因为系统把raid看作一个整体,少了一块硬盘,会认为是发生了错误,要么启动不成功,要么进入紧急模式。所以拔下一块硬盘然后再插入一块新硬盘后,往往系统可以启动。也就是raid对数据的保护和系统正常启动是两个概念。
安装centos6.7
1. CentOS安装过程配raid。参考:http://www.360doc.com/content/13/1209/21/14661619_335823338.shtml。
2. 选择bootloader device时,不要选择U盘,选择两块硬盘中的一个。
配置bootloader
1.似乎bootloader不会同步,需要在新加磁盘上执行grub-install /dev/sdX.
------------------------
可能的问题1:
执行grub-install报错:/dev/sda does not have any corresponding BIOS drive.
解决办法:
[root@zz grub]#grub ## 进入grub grub>find /grub/grub.conf find /grub/grub.conf (hd0,0) (hd1,0) grub>root (hd1,0) grub>setup (hd1) ## 配置hd1 grub>root (hd0,0) grub>setup (hd0) grub>reboot [root@zz grub]#grub-install /dev/sda [root@zz grub]#grub-install /dev/sdb
可能的问题2:
拔下一块硬盘后,系统无法正常启动。显示:
failed to read image
Press any key to enter the menu
Press any key to continue...
解决办法。参考:https://www.centos.org/forums/viewtopic.php?t=2094。
把硬盘接回去,正常启动。
[root@zz ~]#cd /boot/grub/
[root@zz grub]#vim device.map ## 发现,“(hd0) /dev/sdc”把第一块硬盘映射成了/dev/sdc,改为/dev/sda
(hd0) /dev/sdb
(hd0) /dev/sda
[root@zz grub]#vim grub.conf
##原始内容如下:
#boot=/dev/md0
default=0
timeout=5
splashimage=(hd1,0)/grub/splash.xpm.gz
hiddenmenu
title CentOS 6 (2.6.32-573.el6.x86_64)
[b]root (hd1,0)[/b]
kernel ******** ## 省略若干信息
initrd /initramfs-2.6.32-573.el6.x86_64.img
这里只有root (hd1,0),也就是/dev/sdb硬盘的配置,复制一份,把/dev/sda也加上,同时把title也稍微修改一下:
#boot=/dev/md0
default=0
timeout=5
splashimage=(hd1,0)/grub/splash.xpm.gz
hiddenmenu
title CentOS 6 (2.6.32-573.el6.x86_64)
[b]root (hd1,0)[/b]
kernel ******** ## 省略若干信息
initrd /initramfs-2.6.32-573.el6.x86_64.img
title CentOS 6 (2.6.32-573.el6.x86_64.1)
[b]root (hd0,0)[/b]
kernel ******** ## 省略若干信息
initrd /initramfs-2.6.32-573.el6.x86_64.img
:wq回到shell,这时候执行 ,
cat /proc/mdstat
可能会看到如下(示例):
md2 : active raid1 sda3[0] sdb3[1] 4883648 blocks [2/2] [UU] md1 : active raid1 sdb2[2] sda2[0] 195310144 blocks [2/1] [U_] [=>...................] recovery = 8.5% (16775552/195310144) finish=17.0min speed=259783K/sec md0 : active raid1 sdb1[1] sda1[0] 39061952 blocks [2/2] [UU]
表示两块硬盘的其中一个分区正在同步数据([U_]说明一块硬盘是正常,一块不正常),后续操作**需要等待同步完成后进行**。
[root@zz grub]#dracut "initramfs-$(uname -r).img" $(uname -r) ## 不确定是否有用
注意点:
在grub.conf文件中有一行配置:
splashimage=(hd1,0)/grub/splash.xpm.gz
这里面的(hd1,0)需要修改成目前还链接在电脑上的硬盘的标号。如果拔下来的硬盘是hd1,即/dev/sdb/,那么还在电脑内的硬盘为hd0,则这里需要修改成:
splashimage=(hd0,0)/grub/splash.xpm.gz
最后,在**启动界面**,需要手动选择对应磁盘的title。比如目前电脑磁盘为hd0,那么就选择CentOS 6 (2.6.32-573.el6.x86_64.1)系统启动,否则可能会默认启动hd1的CentOS 6 (2.6.32-573.el6.x86_64),找不到硬盘报错。
测试
1. 测试时,在格式化一块硬盘之后,需要在BIOS里设置一下启动顺序,把已经格式化的硬盘放在最后一位,否则可能出错。
2. 使用parted确认raid信息,同时也可以看到/dev/sda/对应的硬盘编号。 (fdisk不能支持大于2T的磁盘,而且不支持gpt分区,所以这里使用parted工具)
参考:http://www.chinaz.com/server/2016/1017/595444.shtml
parted -l
3. 先用mdadm命令删除一块raid硬盘,这里选择删除sdb。
mdadm --manage /dev/md0 --fail /dev/sdb1 mdadm --manage /dev/md0 --remove /dev/sdb1 mdadm --manage /dev/md1 --fail /dev/sdb2 mdadm --manage /dev/md1 --remove /dev/sdb2 mdadm --manage /dev/md2 --fail /dev/sdb3 mdadm --manage /dev/md2 --remove /dev/sdb3 cat /prco/mdstat
4. 格式化硬盘然后重启:
mkfs /dev/sdb
reboot
5. 查看/dev/sda的分区信息
parted /dev/sda/ unit B print
6. 重新添加/dev/sdb到raid1 ,依次执行:
parted /dev/sdb mklabel msdos ## 这里的分区标志和现有磁盘相同,可能是“gpt” mkpart primary XXX1B YYY1B ## 按照/dev/sda/的分区大小创建分区 mkpart primary XXX2B YYY2B mkpart primary XXX3B YYY3B set 1 raid on set 2 raid on set 3 raid on quit
回到shell
mdadm --manage /dev/md0 --add /dev/sdb1 mdadm --manage /dev/md1 --add /dev/sdb2 mdadm --manage /dev/md2 --add /dev/sdb3 cat /proc/mdstat
可以看到,两块磁盘正在同步,等待同步完成。
7. 同上配置bootloader,重启。
grub-install /dev/sdb vim /boot/grub/grub.conf vim /boot/grub/device.map parted -l reboot
8. 测试结果
parted -l df -h cat /proc/mdstat mdadm --detail /dev/md0 mdadm --detail /dev/md1 mdadm --detail /dev/md2
grub2的介绍可以参考鸟哥系列:http://linux.vbird.org/linux_basic/0510osloader.php#grub