在使用Linux的过程中,难免会出现开机提示grub >而无法启动,可能是系统中/boot/grub文件丢失等原因造成的,当出现此问题的时候只要系统分区没有格式化一般是可以修复的,下面就以虚拟机为例,删除/boot分区,在linux救援模式下重新修复:
实验使用的系统为Centos 6.5 x86_64
1、删除boot分区:会导致gurb和linu内核丢失,然后重启:
此时系统重启后已经完全无法再次启动,如下:
2、使用光盘镜像引导系统,并选择救援模式启动:
提示将系统挂载至/mnt/sysp_w_picpath:
2、将根切换至之前的系统:
3、创建光盘挂载目录并挂载光盘:
4、安装kerner包,会生成/boo目录以及内核及initramfs
5、修复grub,首先要查看一下自己的磁盘分区情况,以确认grub安装在那个磁盘上:
为第一块磁盘安装grub引导:
6、确认geub目录已经生成:
此时系统仍然无法正常启动,因为确认grub.conf文件,可以尝试重启看一下界面:
5、在grub界面指定kernel和initramfs所在路径启动,可以操作的命令有:
grub>kernel 内核文件 //设置内核文件的路径
grub>initrd 镜像文件名 //设置镜像路径
grub>boot //启动指定操作系统
grub>help //获取帮助
grub>reboot //重启系统
grub>md5-crypt //生成口令的MD5密文
grub>setup (hdx[,y]) //安装GURB到MBR/指定分区的引导扇区中
grub>hide 分区 //隐藏分区
grub>cat 文件名 //显示文件内容
grub>find 文件名 //查找文件
grub>rootnoveify (hdx,y) //设置根设备所对应的分区,但不检查加载点
grub>chainloader 文件名 //加载指定的文件
在此指定linux内核和initramfs文件路径,并启动linux系统:
注:
grub> root (hd0,1) #是说跟分区在第一块硬盘的第二个分区
grub> kernel /boot/vmlinuz-2.6.32-431.el6.x86_64 ro root=/dev/sda2 #指明内核路径和根分区
grub> initrd /boot/initramfs-2.6.32-431.el6.x86_64.img #指明initramfs路径启动系统加载驱动
grub> boot #启动上面指定的系统,如果是reboot就等于重启整个系统了,刚才的设置就失效了
此时已经可以引导系统启动了,但是还没有grub.conf文件,可以在系统启动后编写一个grub.conf文件即可
6、编写grub.conf文件:
可以看到,此时系统是没有grub.conf文件的,如果重启系统后就无法正常开机了,除非在grub界面指定内核和驱动文件的路径:
创建grub.conf文件:
注:kernel一行后面root=/dev/sda2是指的根分区所在的磁盘,假如boot分区和根分区没有在一起,则grub.conf文件要写明boot分区和根分区,另外不推荐安装磁盘分区的方式写根分区的路径,因为有可能系统重启后磁盘好会出现变化,因此推荐使用UUID的方式表明,每个分区都有自己的UUID,是在整个系统中唯一的身份标示,可以使用命令blkid /dev/sda2获取。
7、最后重启系统,以硬盘直接启动测试;
系统已经正常启动完成!
总结:修复grub是个漫长的过程,下午用了三个多小时的时间写博客和修复系统,修复期间为了排错,虚拟机重启了至少几十次,因此要有耐心、认真的去做一件事,才能做的最好!