Linux系统启动故障修复的问题

2个回答

写回答

linux在启动过程中会出现一些故障,导致系统无法正常启动,本文列举了几个应用单用户模式、GRUB命令操作、linux救援模式的典型故障修复案例帮助读者了解此类问题的解决。

一、单用户模式

linux提供了单用户模式(类似Windows安全模式),可以在最小环境中进行系统维护。

在单用户模式(运行级别1)中,linux引导进入根shell,网络被禁用,只有少数进程运行。单用户模式可以用来修改文件系统损坏、还原配置文件、移动用户数据等。

以下列举了几个单用户模式修复系统故障的典型案例:

案例一:硬盘扇区错乱

在启动过程中最容易遇到的问题就是硬盘可能有坏道或扇区错乱(数据损坏)的情况,这种情况多由于异常断电、不正常关机导致。

此种问题发生,在系统启动的时候,屏幕会显示:

Pressrootpasswordorctrl+D:

此时输入root密码系统自动进入单用户模式,输入“fsck-y/dev/hda6”(fsck为文件系统检测修复命令,“-y”设定检测到错误自动修复,/dev/hda6为发生错误的硬盘分区,请依据具体情况更改此参数),系统修复完成后,用命令“reboot”重新启动即可。

案例二:root密码忘记

在单用户模式中,linux不需要root密码(RedHat系统不需要root密码,但SuSe则需要,不同linux系统稍有差别,本文以FedoraCore6为例讲解),这使更改root密码非常容易。

了解当系统引导进入多用户模式失败时,如何进入单用户模式,非常重要。

1、在系统启动过程中,会出现图1所示画面,按任意键,进入GRUB菜单选项。

图1进入GRBU菜单选项

若希望以后无此提示,直接进入GRUB菜单选项,删除配置文件grub。

conf中“hiddenmenu”项即可。

2、按“e”键编辑GRUB引导菜单选项,图2显示为按“e”键后的GRUB屏幕。

图2GRUB引导菜单选项

通过箭头键下移到kernel行,并按“e”键,得到图3中显示的编辑界面:

图3kernel行编辑界面

在尾行光标处添加single,按回车键返回前一个屏幕,按“b”键进行引导,则系统自动进入单用户模式,如果要改变root密码,则执行命令:

sh-3。

1#passwdroot

更改成功后,执行命令exit退出重启即可。

我们可以在单用户模式中去纠正阻止系统正常启动的很多问题,比如:1、禁用可能中止系统运行的服务如禁用Samba服务,则执行:sh-3。

1#chkconfigsmboff下次系统引导就不会启动Samba服务了。

2、更改系统缺省运行级如果XWindow无法启动或者出现故障,可以编辑/etc/inittab文件,采用文本方式登录,更改initdefault引导级别为3:id:3:initdefault:

案例三、GRUB选项设置错误

下图是一个系统管理员不希望看到的控制台信息,“Error15”显示系统无法找到grub。

conf中指定的内核。

图4GRUB引导错误信息

我们观察发现因为打字错误,内核文件的“vmlinuz”打成了“vmlinux”,所以系统无法找到内核的可执行文件。我们可以按任意键回到GRUB编辑界面,修改此错误,回车保存后按“b”键即可正常引导,当然不要忘记进入系统后修改grub。

conf文件中此处错误。

这是很多初学linux的用户在修改GRUB设置时很容易犯的错误,出现此黑屏提示时注意观察报错信息,即可针对性修复。

二、GRUB引导故障排除

有时linux启动后会直接进入GRUB命令行界面(只有“grub>”提示符),此时很多用户就选择了重新安装GRUB甚至重新安装系统。

其实一般而言此故障的原因最常见的有两个:一是GRUB配置文件中选项设置错误;二是GRUB配置文件丢失(还有少数原因,如内核文件或镜像文件损坏、丢失,/boot目录误删除等),如果是第一种情况,可以首先通过GRUB命令引导系统后修复;若是第二种情况,则要使用linux救援模式修复了(本文后续有描述)。

首先,我们需要了解GRUB启动系统的引导过程,grub。conf文件中主要的配置选项如下(注意,GRUB配置文件为/boot/grub/grub。conf,/etc/grub。conf只是此文件的软链接):

titleFedoraCore(2。

6。18-1。2798。fc6)

root(hd0,0)

kernel/boot/vmlinuz-2。6。18-1。2798。fc6roroot=LABEL=/rhgbquietinitrd/boot/initrd-2。

6。18-1。2798。fc6。img

其中“title”段指定了GRUB引导的系统:“root”段指定了/boot分区所在的位置:“kernel”段指定了内核文件所在位置,内核加载时权限属性为只读(“ro”)以及指定根分区所在位置(root=LABEL=/);initrd指定了镜像文件所在位置。

所以GRUB在引导时顺序为首先加载/boot分区,然后依次载入内核与镜像文件。

案例:“titleFedoraCore(2。6。18-1。2798。fc6)”段被误删除

此时,系统启动后会自动进入“GRUB>”命令行,为排除故障我们可以依次做如下操作:

1、查找/boot/grub/grub。

conf文件所在分区GRUB>find/boot/grub/grub。conf(hd0,0)

2、查看grub。conf文件错误GRUB>cat(hd0,0)/boot/grub/grub。conf建议系统安装设置好后,要将grub。

conf文件备份,如果有备份文件如grub。conf。bak,则此时可以查看备份文件,与当前文件比较,发现错误:GRUB>cat(hd0,0)/boot/grub/grub。conf。bak

3、确认错误后,先通过命令行方式完成GRUB引导,进入系统后再行修复grub。

conf文件错误:1)指定/boot分区root(hd0,0)

2)指定内核加载kernel/boot/vmlinuz-2。6。18-1。2798。fc6roroot=LABEL=/rhgbquiet3)指定镜像文件所在位置initrd/boot/initrd-2。

6。18-1。2798。fc6。img

提示:GRUB支持tab键命令补全功能

4、从/boot分区启动boot(hd0,0)

命令行模式可以在GRUB菜单模式中通过按“c”键调用,也可以用于测试新编译的内核(设置kernel、initrd引导新内核及镜像文件)。

增加对GRUB引导以及linux系统引导知识的了解将对此类故障排除大有帮助。

三、linux救援模式应用

当系统连单用户模式都无法进入时或出现GRUB命令行也不能解决的引导问题,我们就需要使用linux救援模式来进行故障排除了。

步骤如下:

1、将linux安装光盘(如果使用CD光盘,则放入第一张引导光盘)放入光驱,设置固件CMOS/BIOS为光盘引导,当linux安装画面出现后,在“boot:”提示符后输入“linuxrescue”回车进入救援模式。

(想了解救援模式详细信息,还可以按F5键查看)

图5进入救援模式。

举报有用(0分享收藏

Linux系统启动故障的修复通常包括检查启动日志、验证启动顺序、修复文件系统错误、检查硬件问题等步骤。

首先,可以通过启动时进入GRUB菜单,选择高级选项进入单用户模式或恢复模式,查看启动日志信息,通常在/var/log/boot.log或/syslog文件中,以确定故障的具体原因。

其次,检查启动顺序是否正确,确保硬盘、USB设备等启动顺序设置正确,可以通过BIOS设置界面调整。

如果文件系统损坏,可以使用fsck工具进行修复,例如在单用户模式下输入fsck -f /dev/sda1来修复根分区的文件系统错误。

最后,检查硬件问题,例如内存、硬盘等是否正常工作,可以使用memtest86+测试内存,使用smartctl工具测试硬盘健康状况。

举报有用(0分享收藏

Copyright © 2025 IZhiDa.com All Rights Reserved.

知答 版权所有 粤ICP备2023042255号