raid1磁盘更换---测试
写在前面的话,研究下来,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,)
(hd1,)
grub>root (hd1,)
grub>setup (hd1) ## 配置hd1
grub>root (hd0,)
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[] sdb3[]
blocks [/] [UU] md1 : active raid1 sdb2[] sda2[]
blocks [/] [U_]
[=>...................] recovery = 8.5% (/) finish=.0min speed=259783K/sec md0 : active raid1 sdb1[] sda1[]
blocks [/] [UU]
表示两块硬盘的其中一个分区正在同步数据([U_]说明一块硬盘是正常,一块不正常),后续操作**需要等待同步完成后进行**。
[root@zz grub]#dracut "initramfs-$(uname -r).img" $(uname -r) ## 不确定是否有用
注意点:
在grub.conf文件中有一行配置:
splashimage=(hd1,)/grub/splash.xpm.gz
这里面的(hd1,0)需要修改成目前还链接在电脑上的硬盘的标号。如果拔下来的硬盘是hd1,即/dev/sdb/,那么还在电脑内的硬盘为hd0,则这里需要修改成:
splashimage=(hd0,)/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 raid on
set raid on
set 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
raid1磁盘更换---测试的更多相关文章
- linux 磁盘IO测试工具:FIO (同时简要介绍dd工具测试)
FIO是测试IOPS的非常好的工具,用来对硬件进行压力测试和验证.磁盘IO是检查磁盘性能的重要指标,可以按照负载情况分成照顺序读写,随机读写两大类. 目前主流的第三方IO测试工具有fio.iomete ...
- 【Linux】磁盘读写 测试
一.如何查看当前磁盘的IO使用情况 使用命令:iotop Total DISK READ: 3.89 K/s | Total DISK WRITE: 0.00 B/s TID PRIO USER DI ...
- (转)AIX rootvg 镜像创建与磁盘更换
# prtconf | grep disk # chdev -l hdisk1 -a pv=yes # extendvg rootvg hdisk1 # chvg -Qn rootvg # lsvg ...
- Linux dd工具磁盘读写测试分析
话说,Linux 自带的dd工具测试硬盘读写速度只能提供一个大概的测试结果,而且是连续IO 而不是随机IO ,理论上文件规模越大,测试结果越准确.理论上bs越大,所测得性能越高. 上句来自网上,是不是 ...
- 磁盘io测试工具
1. ATTO Disk Benchmark 2.DiskSpd磁盘性能测试工具
- 如何对Azure磁盘性能进行测试
Azure的云存储一直是Azure比较自豪的东西,想到AWS的LSA后面有若干个9,搞得大家都以为它的存储最优秀,其实不然,Azure存储到现在没有丢过客户1bit的数据,但是Azure不会去说我们的 ...
- 使用 MegaCLI 检测磁盘状态并更换磁盘
专栏首页阿dai_linux使用 MegaCLI 检测磁盘状态并更换磁盘 原 10
- 1-15-2-RAID1 企业级RAID磁盘阵列的搭建(RAID1、RAID5、RAID10)
大纲: 1.创建RAID1 2.创建RAID5 3.创建RAID10 =============================== 1.创建RAID1 RAID1原理:需要两块或以上磁盘,可添加热备 ...
- DOS命令行(2)——Windows磁盘维护与管理
预备知识 1 -- 磁盘 1.磁盘分区 主磁盘分区.扩展磁盘分区.逻辑分区 主磁盘分区是物理磁盘的一部分,它像物理上独立的磁盘那样工作.对于基本启动记录(MBR)的磁盘,在一个基本磁盘上最多可以创建四 ...
随机推荐
- Linux的概念与体系(转)
学linux就用它了 http://www.cnblogs.com/vamei/archive/2012/10/10/2718229.html
- Linux ls命令
ls:即列表List的意思,用来列出目录下的文件用来列出给定目录下的文件,参数为空默认列出当前目录下的文件. 用法是:ls [选项] [目录] 常用的选项有 -a, –all 列出目录下的所有文件,包 ...
- PAT 1136 A Delayed Palindrome[简单]
1136 A Delayed Palindrome (20 分) Consider a positive integer N written in standard notation with k+1 ...
- FTP服务器文件上传的代码实现
方式一: @Test public void testFtpClient() throws Exception { // 1.创建一个FtpClient对象 FTPClient ftpClient = ...
- python3 爬虫神器pyquery的使用实例之爬网站图片
PyQuery 可让你用 jQuery 的语法来对 xml 进行操作,这和 jQuery 十分类似.如果利用 lxml,pyquery 对 xml 和 html 的处理将更快. 如果对 jQuery ...
- Java 面试总结 面试常问的关键字总结
文章出处http://www.cnblogs.com/IUbanana/p/7116520.html 关键字: final finalize finally throws和throw static关键 ...
- flask扩展 -- flask-script
Flask-Scropt插件:为在Flask里编写额外的脚本提供了支持.这包括运行一个开发服务器,一个定制的Python命令行,用于执行初始化数据库.定时任务和其他属于web应用之外的命令行任务的脚本 ...
- jQuery HTML操作学习笔记
学习资料 jQuery教程 获取 1.获取.设置元素的内容 1.1获取或设置目标元素的文本内容 语法 $(selector).text(); 获取元素文本内容 $(selector).text(con ...
- 斐迅面试记录—SSL和TLS的区别
SSL 是洋文“Secure Sockets Layer”的缩写,中文叫做“安全套接层”.它是在上世纪90年代中期,由网景公司设计的.(顺便插一句,网景公司不光发明了 SSL,还发明了很多 Web 的 ...
- googleMapReduce
摘要 MapReduce是一个编程模型,也是一个处理和生成超大数据集的算法模型的相关实现.用户首先创建一个Map函数处理一个基于key/value pair的数据集合,输出中间的基于key/value ...