如何修复Linux无法正常启动故障

 没有操作系统能够确保100%可靠。终有一天,即使Linux也会无法启动。本文为你提供一些在Linux工作站无法正常启动时所采用的策略。

  不管你多么喜爱你的Linux机器,有时候你都必须恢复你的系统。是的,即使一台Linux机器也可能遭受系统崩溃:不管是由于视频配置错误、内核更新出错、或是由于init脚本配置错误,这种情况都是必然的。我看到过大量这种情况——即使在我自己的机器上,大多数是由于X配置出错——这确实令人沮丧。

  在我看来,重新安装系统并不是最佳救援计划。有时候,最佳救援计划甚至不需要从救援磁盘启动。本文将为如何避免系统崩溃提供一些提示和诀窍,帮助你建立恢复崩溃的Linux机器所需的工具。

  使用正确的运行级别

  安装好一个新的Linux系统后,我立即采取措施以确保灾难不会轻易发生。其中一个措施就是编辑系统的运行级别。运行级别告诉系统离采用引导过程还有多远。运行级别分为六个等级:

  0级:停止(不设置initdefault)

  1级:单用户模式

  2级:多用户模式,没有NFS(与3级相同,如果你没有建立网络)

  3级:完整的多用户模式

  4级:不使用

  5级:X11

  6级:重新启动(不设置initdefault)

  新型的Linux系统几乎总是默认使用运行级5(X11),表示系统在引导完成后,将会在图形登录界面处停止。在某物(或某人)使用X配置前,系统一切正常。

  然后你必须找到一个登录方法。你可以按下[Ctrl][Alt][F7]进入一个基于文本的虚拟窗口,但为什么要这么麻烦呢?相反,我总是在/etc/inittab文件中将运行级更改为3级。你更改的代码为:

  id:5:initdefault:

  它被更改为:

  id:3:initdefault:

  当X出错时,这是一个非常简单的系统恢复方法。

  多内核

  另一个明显的磁盘恢复方法是总是安装一个正常运转的内核。我通常在一个通过yum更新的内核上工作。有时候,内核会出现一些错误,使得我的一台或几台机器无法启动。

  为避免这种情况,我一直保证在机器上使用至少一个正常运行的内核。要解决这个问题,首先应在/etc/yum.conf文件中添加plugins=1,然后应用这段脚本(由RedHat的Jeremy Katz编写),并将它命名为n-installonly.py,保存在/usr/lib/yum-plugins文件中。你可以通过修改tookeep变量(默认为2)的方法更新系统所使用内核的数量。

  知道系统上有一个正常运转的内核,你就可以进行安全升级。如果新内核出错,只需启动旧内核就可以解决新内核上的问题(不管是删除、重新编译还是升级)。

  救援模式

  如果你在使用Red Hat和LILO引导加载器,你就可以插入产品光盘1,并在引导提示符下输入Linuxrescue进入救援模式。启动机器后,你就会看到bash#提示符。在这个模式下,你可以使用许多工具。

  如你所见,有检查硬盘完整性、修复硬盘、检查内核模块、装配设备、以及创建文件系统等的工具。此时是进行救援尝试的最佳时机(如果你使用的是一个Red Hat,或基于Red Hat的系统)。

  另一个救援方法是进入单用户模式,这里你的计算机引导进入运行级1。系统装配你的本地文件系统,但不激活网络。你得到一个可用的系统维护外壳。要进入单用户模式,在LILO提示符下输入:

  Linuxsingle

  或

  Linuxemergency

  建立一张救援CD

  如果你正在使用LILO引入加载器,可以使用一个叫做mkrescue的强大工具。这个工具一般用于创建引导软盘,但也可用来创建ISO。其用法如下。

  如果你使用Mandriva:

  mkrescue --iso --initrd /boot/initrd-KERNEL-NUMBER.img --

  kernel /boot/vmlinuz-KERNEL-NUMBER

  注意:这里的KERNEL-NUMBER指内核的版本号。

  如果你不能确定内核的版本,可以用以下命令找到intrd和vmlinuz的号码:

  uname –r

  运行这个命令后,你就会在运行mkrescue命令的目录中发现一个rescue.iso文件。现在你可以用以下命令建立镜像:

  首先,检查建立CD的设备号码:

  cdrecord –scanbus

  然后用以下命令建立镜像:

  cdrecord dev=0,0,0 rescue.iso

  注意:这里的dev=0,0,0是用上面的scanbus命令查出的号码。

  如果你使用Slackware,使用这些步骤建立一张引导CD:

  mkrescue –iso

  注意:Slackware自动获知在ISO中放入何种内核。

  然后,你可以用建立Mandriva镜像同样的方法建立镜像。

  SystemRescueCD

  SystemRescueCD是一个保存在可引导光盘上的Linux系统,用于在系统崩溃后修复系统和数据。它还可在计算机上方便地执行管理任务,如建立和编辑硬盘分区。它由许多系统实用工具(parted、partimage、fstools)和基本实用工具(编辑器、midnight commander文件管理器和网络工具)构成。

  它使用起来非常简单。只需要从光盘启动你就可以执行一切操作,就像从硬盘启动一样。系统内核支持大多数重要的文件系统(ext2/ext3, reiserfs, reiser4, xfs, jfs, vfat, ntfs, iso9660)和网络(samba和nfs)。

  SystemRescueCD可能是市面上最优秀的救援系统。你不仅可以从光盘上使用这种救援方法,还可以将这个救援系统放在U盘上使用。

  要在一个U盘上建立一个SystemRescueCD,你需要大于256MB的磁盘空间。从Sourceforge下载iso镜像并把它烧制到光盘上。现在你必须在U盘上创建文件系统。使用dmesg命令找出U盘名称,然后用以下代码擦写U盘:

  dd if=/dev/zero of=/dev/sda

  这里的/dev/sda是U盘的名称。

  现在在U盘上安装主引导记录:

  install-mbr /dev/sda

  或

  install-mbr --force /dev/sda(如果命令出错)

  现在建立分散分区:

  parted /dev/sda

  (parted) mkpartfs primary fat32 0 100% // use help or help mkpartfs command to see help

  (parted) print // check if the write was ok

  (parted) quit

  现在已经建立好文件系统,然后将用SystemRescueCD镜像烧制的CD中的文件复制到U盘中。保证你复制的文件等级和CD上的相同。

  现在,使得U盘可以用sysLinux命令启动:

  sysLinux/dev/sda1

  这里的/dev/sda1是磁盘的名称。

  现在你已经建立了一个你可以整天随身携带的救援U盘。由于你使用Linux,你并不需要经常用到它。

  最后总结

  Linux是一个非常稳定的环境,但由于该系统中还有许多其它系统,它们可能会出现错误。虽然我们很容易会由于使用Linux而洋洋自得(因为它存在诸多优点),但了解如何拯救一个系统崩溃的机器也不失为一种明智的做法。

  当然,不是世界上所有的救援系统都能100%地恢复你的系统,因此你可能希望考虑为你的Linux服务器和桌面系统实施一个灾难恢复计划。


你可能感兴趣的:(如何修复Linux无法正常启动故障)