你好,游客 登录 注册 搜索
背景:
阅读新闻

CentOS 6.5 修复grub引导

[日期:2016-07-25] 来源:Linux社区  作者:Linux [字体: ]

在使用Linux的过程中,难免会出现开机提示grub >而无法启动,可能是系统中/boot/grub文件丢失等原因造成的,当出现此问题的时候只要系统分区没有格式化一般是可以修复的,下面就以虚拟 机为例,删除/boot分区,在linux救援模式下重新修复: 实验使用的系统为CentOS 6.5 x86_641、删除boot分区:会导致grub和linu内核丢失,然后重启:


此时系统重启后已经完全无法再次启动,如下:

2、使用光盘镜像引导系统,并选择救援模式启动:

提示将系统挂载至/mnt/sysimage:

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、最后重启系统,以硬盘直接启动测试;



系统已经正常启动完成!

更多CentOS相关信息见CentOS 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=14

本文永久更新链接地址http://www.linuxidc.com/Linux/2016-07/133521.htm

linux
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款