出于各种各样的目的,不少人会选择在电脑上同时安装Windwos操作系统与Linxu操作系统。如笔者电脑上就同时装有这两个操作系统。在部署类似的多操作系统的时候,不少Linux系统工程师会建议大家先安装Windows操作系统,然后再安装Linux操作系统。因为如果反过来,先安装Linux操作系统,再安装Windows操作系统,则很可能Windows操作系统安装成功后,会无法进入Linux操作系统,甚至两个操作系统都无法启动。这主要跟两个操作系统加载的方式不同有关。Windows操作系统采用的是间接加载的方式,而Linux操作系统则同时同时间接加载与直接加载。
直接加载是指操作系统启动时控制权交给开机管理程序时,立即加载操作系统的内容的加载方式。这种加载方式的基本流程是开机管理程序、操作系统内核。也就是说中间没有多余的环节,在加载过程中,没有中间步骤介于开机管理程序与操作系统内核之中。为此就被叫做直接加载。
间接加载则与直接加载不同。间接加载是指开机管理程序仅单的指到存放操作系统分区上的第一个扇区,然后由第一个扇区内的程序代码去加载操作系统内和。其流程为开机管理程序、操作系统上的第一个扇区上的代码、操作系统内核。与直接加载模式的流程进行比较,就可以发现其中间多了一个环节,即执行操作系统上的第一个扇区上的代码。
虽然这看起来只是一个很小的差异,但是对于双系统安装来说有很大的影响。因为微软的操作系统只支持间接加载模式。在安装微软操作系统时,Windows操作系统会完全覆盖MBR引导记录,并破坏现有的开机程序。为此如果先安装Linux操作系统,然后再安装Windows操作系统,则就会破坏原有的开机程序,导致Linux操作系统无法启动,更严重者两个操作系统都将无法启动。为此在安装多个操作系统的时候,最好能够先安装Windows操作系统,然后再安装Linux操作系统。因为Linux操作系统其支持直接加载和间接加载两种开机方式。当在部署有Windwos操作系统的时候,系统会自动采用间接加载模式,其与Windows操作系统兼容。而在没有Windows操作系统的时候,其默认会采用直接加载方式,以提高系统开机的效率。
一、修复Linux的开机引导程序。
如果先安装Linux操作系统,然后再按照Windows操作系统,导致Linux操作系统无法启动(或者两者都无法启动),此时需要重新安装操作系统来解决问题呢?答案是否定的。可以有许多方式来修复Linux操作系统的开机引导程序。不过开机程序的种类不同,其修复的方式略有差异。笔者这里以Linux操作系统上最有名的GRUB开机管理程序为例,谈谈如何进行修复。
为了让操作系统内核能够顺利加载到内存中,就需要有一个开机管理程序来进行加载与初始化。Grub在其中就是起到这个作用。通过GRUB的操作界面,可以选取加载一种操作系统或者Linux操作系统内核,以及传递或者查看操作系统参数到内核中。当GURB开机管理程序决定启动的操作系统时,这个操作系统开机管理程序就会将其加载到内存,并将机器控制权交给被其启动的操作系统。
为此如果操作系统无法正常启动,如果排除硬件方面的故障原因之外,则最大的可能就是由于开机管理程序中的MBR开机记录损坏所致。很多原因都可能导致这个记录被损坏或者覆盖。如病毒的原因,意外死机等等。不过大部分情况下,这都是由于人为的因数所造成的。如在安装操作系统时,选择的顺序不对或者安装的方式不对,从而导致原有的MBR引导记录被不小心覆盖。通常情况下,如果先安装Linux操作系统,然后再安装Windows操作系统,都会遇到这种故障。因为在安装Windows操作系统的过程中,会将原有的MBR记录覆盖掉,从而导致系统无法启动。
遇到这种情况时,最简单的方式就是利用应急软盘来修复故障。如在安装完Linux操作系统后,系统都会提醒系统管理员建立一张系统启动盘。通过这张软件可以修复大部分的启动错误。如发生这种MBR引导记录被覆盖而无法启动的情况,则可以插入这张启动启动盘,然后执行grub-install /dev/hda命令,系统就会自动重新安装MBR程序代买,从而让操作系统能够在不重新安装的情况下恢复正常启动。
二、其他原因导致的Linux操作系统无法启动问题的解决方法。
除了由于双系统安装顺序选择不当,导致操作系统无法启动之外,还有很多原因也会导致操作系统无法启动。笔者这里就举一些简单的例子,给大家解决问题出一个思路。
如由于丢失initrd目录而导致操作系统无法启动。有时候Linux操作系统启动过程中,会提示一个错误信息:umount /initrd/proc failed(不能够挂载initrd目录),然后操作系统就无法正常启动了。发生这种启动错误的原因主要是在系统根目录下由于某些错误的操作导致initrd目录的丢失。只要这个目录被不小心删除了,则此时系统已经无法正常启动。遇到这种情况时,我们系统管理员不需要重新安装操作系统,可以使用安装盘或者引导盘进入linux操作系统的恢复模式下。如使用的是redhat操作系统,则就可以直接F5,然后在命令行窗口中输入linux rescue命令,即可以进入rescue(修复)模式。进入到修复模式后,系统管理员需要输入命令:chroot /mnt/sysimage,,以进入原系统目录。然后在根目录下新建一个目录initrd(注意必需全部都是小些,字母一个都不能够差),然后重新启动操作系统,就可以顺利启动了。其实这个Linux操作系统的修复模式跟微软操作系统的修复控制台类似,都可以用来解决操作系统无法启动的问题。另外有些Linux操作系统安装程序存在着一定的Bug,即使先安装Windows操作系统,然后再安装Linux操作系统,安装成功后仍然会遇到Windows操作系统无法启动的问题。此时通常情况下,Linux操作系统仍然会正常启动。遇到这种情况时,该如何处理呢?这往往需要根据错误提示来判断到底问题出在哪里,然后再有针对性的采取解决措施。如有时候,部署完双系统后,启动Windows操作系统时,会出现“/system32/hal.dll损坏或失败,清重新安装拷贝”等类似的错误信息。其实,如果遇到这个错误信息的话,并不是Linux操作系统的错。这主要是微软的采用的开机管理程序灵活性不强所导致的,也就是说,并不是Linux操作程序引起的问题。导致这个问题的主要原因是硬盘分区数变动后(安装Linux操作系统可能需要删除原有的分区并进行格式化归Linux操作系统使用),引导分区号发生了变化。而此时Windows操作系统的启动配置文件boot.int 中使用ARC法表示分区。这种标示方法是一种基于编号的磁盘表示方法。为此,当分区号发生了变化之后,开启管理程序就无法识别这个配置分区所表示的内容,从而导致Windows操作系统无法启动。通常情况下,如果部署的是多个版本的Linux操作系统的话,就不会发生这个问题。
遇到这个问题该如何解决呢?解铃人还须系铃人,此时还需要Windows启动盘的帮助。如可以在控制台下修复boot.int文件;也可以通过覆盖安装来修复启动配置文件;也可以利用Windows操作系统的安装CD来启动操作系统进行修复。如利用CD启动进入到DOS模式,然后使用map arc命令得到正确的磁盘映射关系。再根据这个信息来修改boot.ini配置文件即可。在解决这个问题的过程中,基本上没有多Linux操作系统的内容进行更改。可见,这主要是Windwos操作系统的问题所引起的。所以根据系统启动的错误提示,然后来判断问题到底出在哪里,在采取对应的措施来进行解决。如此才能够对症下药,解决系统启动错误问题。