热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

解决grub引导错误的一次经历

我的电脑上一共是两块硬盘,1块固态硬盘(sda)装了win7,另外一块普通硬盘(sdb)装了ubuntu和centos两个系统,系统启动的引导是装在sdb上面的ubuntu的grub2,它负责选择

  我的电脑上一共是两块硬盘,1块固态硬盘(sda)装了win7,另外一块普通硬盘(sdb)装了ubuntu和centos两个系统,系统启动的引导是装在sdb上面的ubuntu的grub2,它负责选择不同的操作系统来启动,OK,背景交代完了,接下来开始讲述我们出现的问题。

  昨天晚上给sdb新添加了一个分区,如下:

 1 Disk /dev/sdb: 500.1 GB, 500107862016 bytes
 2 255 heads, 63 sectors/track, 60801 cylinders, total 976773168 sectors
 3 Units = sectors of 1 * 512 = 512 bytes
 4 Sector size (logical/physical): 512 bytes / 4096 bytes
 5 I/O size (minimum/optimal): 4096 bytes / 4096 bytes
 6 Disk identifier: 0xa887a887
 7 
 8    Device Boot      Start         End      Blocks   Id  System
 9 /dev/sdb1            2048   125829119    62913536   83  Linux
10 /dev/sdb2       125829246   970502711   422336733    f  W95 Ext'd (LBA)
11 Partition 2 does not start on physical sector boundary.
12 /dev/sdb5       125829248   221983352    48077052+   7  HPFS/NTFS/exFAT
13 /dev/sdb6       221983424   228274807     3145692    b  W95 FAT32
14 /dev/sdb7       228274872   518603944   145164536+   7  HPFS/NTFS/exFAT
15 /dev/sdb8       518604008   782021941   131708967    7  HPFS/NTFS/exFAT
16 /dev/sdb9       782024704   918054911    68015104   83  Linux
17 /dev/sdb10      918056960   934834175     8388608   83  Linux
18 /dev/sdb11      934836224   951613439     8388608   83  Linux
19 /dev/sdb12      951615488   960004095     4194304   82  Linux swap / Solaris
20 /dev/sdb13      960004159   970502711     5249276+  83  Linux
21 Partition 13 does not start on physical sector boundary.

  其中那个13行的sdb6就是我新添加的分区,由于这个分区是在磁盘中间添加的所以就导致后面的分区号全部变了(比如centos的根目录原来装在sdb8,现在变成了sdb9了),我的ubuntu的根目录是装在sdb1中,由于它的分区号还没有改变,所以ubuntu系统还能正常启动,而centos系统就启动不了了!

 

  启动不了我就得去排除错误啊,刚开始我就想着是引导的问题,于是我在ubuntu下面调用了update-grub命令,来更新一下grub2的启动条目,更新的结果是这样的:

Generating grub configuration file ...
Found background image: ubuntu_kylin_grub_bg.tga
Found linux image: /boot/vmlinuz-3.13.0-46-generic
Found initrd image: /boot/initrd.img-3.13.0-46-generic
Found linux image: /boot/vmlinuz-3.13.0-32-generic
Found initrd image: /boot/initrd.img-3.13.0-32-generic
Found memtest86+ image: /boot/memtest86+.elf
Found memtest86+ image: /boot/memtest86+.bin
Found Windows 7 (loader) on /dev/sda1
Found CentOS release 6.6 (Final) on /dev/sdb9
done

  从上面可以看到,三个操作系统都找到了,现在应该能正常启动了吧,我重启试了试,centos启动还是失败。。。。

 

  后来我有在想,我的centos系统的home目录和var目录是单独的分区,是不是它启动的时候自动挂载出问题了,于是我又去修改centos的/etc/fstab文件,原来我是用分区号来标识分区的(比如/dev/sdb9之类的),这里我就全部改成了用UUID来标识分区。这里还学到了一个小技巧,原来分区的UUID号码都保存在/dev/disk/by-uuid/这个目录下面,都保存的是软链接,ll一下就可以看到它指向哪块硬盘了,如下:

        

  我改了fstab之后,再来重启系统,发现还是不行。这我就非常郁闷了,一直在想问题出在哪里?后来我又看了一下grub2的配置文件(grub.cfg),终于发现问题还是在那个启动命令上面,如下所示:

 1 menuentry 'CentOS release 6.6 (Final) (on /dev/sdb9)' --class gnu-linux --class gnu --class os $menuentry_id_option 'osprober-gnulinux-simple-d24c3228-5ffc-4937-8411-a69681c3b54e' {
 2         insmod part_msdos
 3         insmod ext2
 4         set root='hd1,msdos9'
 5         if [ x$feature_platform_search_hint = xy ]; then
 6           search --no-floppy --fs-uuid --set=root --hint-bios=hd1,msdos9 --hint-efi=hd1,msdos9 --hint-baremetal=ahci1,msdos9  d24c3228-5ffc-4937-8411-a69681c3b54e
 7         else
 8           search --no-floppy --fs-uuid --set=root d24c3228-5ffc-4937-8411-a69681c3b54e        fi
 9         linux /boot/vmlinuz-2.6.32-504.12.2.el6.i686 ro root=/dev/sdb8 rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFOnT=latarcyrheb-sun16 crashkernel=128M KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM rhgb quiet vga=791
10         initrd /boot/initramfs-2.6.32-504.12.2.el6.i686.img
11 }

  这是grub.cfg文件中关于centos启动的部分,在第九行linux命令中,它选择好了内核以只读命令来挂载根文件系统的时候,选择的分区是sdb8,而此时sdb8已经变成了windows的ntfs分区,所以此时我的系统启动的时候,就会提示一大串的无法识别文件系统类型(ntfs),只要把这里改成sdb9,我的系统就能正常启动了!

^ o ^

 

  启动之后,我还没高兴多久呢,发现在ubuntu下面运行一遍update-grub命令,那么grub.cfg文件又被覆盖了。。没办法,还得继续分析!

  经过分析之后,发现centos的那个启动条目是由/etc/grub.d/30_os-prober这个配置文件产生的,而在这个文件中,linux-boot-prober命令最终生成了grub.cfg文件中的第9行中root命令后面跟着的分区名!而这个linux-boot-prober命令就是查找给定的分区名中的类似于"menu.lst"的配置文件,结果我最终发现,问题还是出在centos系统的配置文件上,如下所示:  

1 title CentOS (2.6.32-504.12.2.el6.i686)
2         root (hd0,9)
3         kernel /boot/vmlinuz-2.6.32-504.12.2.el6.i686 ro root=/dev/sdb8 rd_NO_LUKS rd_NO_LVM LANG=en_US.UTF-8 rd_NO_MD SYSFOnT=latarcyrheb-sun16 crashkernel=128M  KEYBOARDTYPE=pc KEYTABLE=us rd_NO_DM rhgb quiet vga=791
4         initrd /boot/initramfs-2.6.32-504.12.2.el6.i686.img

  我原来只改了第2行的root命令选择的分区,而没有改第三行中root命令选择的分区,这样我的系统还是启动不了。。

 

  OK,把centos的配置文件一改,问题总算都是解决了!^ . ^


推荐阅读
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • ios中级面试题(二)
    1.如何追踪app崩溃率,如何解决线上闪退当iOS设备上的App应用闪退时,操作系统会生成一个crash日志,保存在设备上。crash日志上有很多有用的信息,比如每个正在执行线程的 ... [详细]
  • mysql innodb redolog_MySQL · 引擎特性 · InnoDB redo log漫游(转)
    前言InnoDB有两块非常重要的日志,一个是undolog,另外一个是redolog,前者用来保证事务的原子性以及InnoDB的MVCC& ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • centos安装Mysql的方法及步骤详解
    本文介绍了centos安装Mysql的两种方式:rpm方式和绿色方式安装,详细介绍了安装所需的软件包以及安装过程中的注意事项,包括检查是否安装成功的方法。通过本文,读者可以了解到在centos系统上如何正确安装Mysql。 ... [详细]
  • iOS开发Debug和Release的理解
    2019独角兽企业重金招聘Python工程师标准参考:http:blog.csdn.netmad1989articledetails406580331&# ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • IB 物理真题解析:比潜热、理想气体的应用
    本文是对2017年IB物理试卷paper 2中一道涉及比潜热、理想气体和功率的大题进行解析。题目涉及液氧蒸发成氧气的过程,讲解了液氧和氧气分子的结构以及蒸发后分子之间的作用力变化。同时,文章也给出了解题技巧,建议根据得分点的数量来合理分配答题时间。最后,文章提供了答案解析,标注了每个得分点的位置。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
author-avatar
丁扣其
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有