`
shinepaopao
  • 浏览: 145736 次
社区版块
存档分类
最新评论

几种Linux常见故障的排除方法

阅读更多

我发现Linux系统在启动过程中会出现一些故障,导致系统无法正常启动,我在这里写了几个应用单用户模式、GRUB命令操作、Linux救援模式的故障修复案例帮助大家了解此类问题的解决。

(一)单用户模式

Linux系统提供了单用户模式(类似Windows安全模式),可以在最小环境中进行系统维护。在单用户模式(运行级别1)中,Linux引导进入根shell,网络被禁用,只有少数进程运行。单用户模式可以用来修改文件系统损坏、还原配置文件、移动用户数据等。

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

案例一:root密码忘记

在单用户模式中,Linux不需要root密码(Red Hat系统不需要root密码,但SuSe则需要,不同Linux系统稍有差别,本文以Fedora Core 6为例讲解),这使更改root密码非常容易。了解当系统引导进入多用户模式失败时,如何进入单用户模式,非常重要。

1、 在系统启动过程中,会出现开始界面,按任意键,进入GRUB菜单选项。

若希望以后无此提示,直接进入GRUB菜单选项,删除配置文件grub.conf中“hiddenmenu”项即可。

2、 按“e”键编辑GRUB引导菜单选项,按“e”键后的GRUB屏幕。通过箭头键下移到kernel行,并按“e”键,

3、在{敏感词}光标处添加single,按回车键返回前一个屏幕,按“b”键进行引导,则系统自动进入单用户模式,如果要改变root密码,则执行命令:sh-3.1# passwd root

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

大家可以在单用户模式中去纠正阻止系统正常启动的很多问题,比如:

1、 禁用可能中止系统运行的服务如禁用Samba服务,则执行:sh-3.1# chkconfig smb off下次系统引导就不会启动Samba服务了。

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

案例二:硬盘扇区错乱

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

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

案例三、GRUB选项设置错误

“Error 15”显示系统无法找到grub.conf中指定的内核。 GRUB引导错误信息,我们观察发现因为打字错误,内核文件的“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只是此文件的软链接):

title Fedora Core (2.6.18-1.2798.fc6)
root (hd0,0)
kernel /boot/vmlinuz-2.6.18-1.2798.fc6 ro root=LABEL=/ rhgb quiet initrd /boot/initrd-2.6.18-1.2798.fc6.img

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

案例:“title Fedora Core (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.fc6 ro root=LABEL=/ rhgb quiet 3)指定镜像文件所在位置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:”提示符后输入“linux rescue”回车进入救援模式。(想了解救援模式详细信息,还可以按F5键查看)

2、系统会检测硬件,引导光盘上的Linux环境,依次提示你选择救援模式下使用的语言(建议选择默认的英文即可,根据笔者测试,部分Linux系统选择中文会出现乱码);键盘设置用默认的“us”就好;网络设置可以根据需要,大部分故障修复不需要网络连接,可不进行此项设置,选择“No”。

3、接下来系统将试图查找根分区,出现挂载提示,设置默认在救援模式,硬盘的根分区将挂载到光盘Linux环境的/mnt/sysimage目录下,默认选项“continue”表示挂载权限为读写:“Read-only”为只读,如果出现检测失败可以选择“skip”跳过。此处,因为要对系统进行修复,所以需要有读写权限,一般选择默认选项“continue”。

进入下一步后,系统提示执行“chroot /mnt/sysimage”命令,可以将根目录挂载到我们硬盘系统的根目录中去。

案例一:双系统启动修复

当我们安装双系统环境,先安装Linux再安装Windows;或者已经安装好双系统环境的Windows损坏,在重新安装Windows后,保存 GRUB的MBR(Master Boot Record,主引导记录)会被Windows系统的自举程序NTLDR所覆盖,造成Linux系统无法引导。

1、如果要恢复双系统引导,首先用上述方法进入救援模式,执行chroot命令如下:

sh-3.1# chroot /mnt/sysimage

2、将根目录切换到硬盘系统的根目录中,然后执行grub-install命令重新安装GRUB:

sh-3.1# grub-install /dev/hda

“/dev/hda”为硬盘名称,如使用SCSI硬盘或Linux安装在第二块IDE硬盘,此项设置要做相应调整。

3、然后依次执行exit命令,退出chroot模式及救援模式(执行两次exit命令):

sh-3.1# exit

系统重启后,将恢复GRUB引导的双系统启动。

案例二:系统配置文件丢失修复

系统在引导期间,很重要的一个过程就是init进程读取其配置文件/etc/inittab,启动系统基本服务程序及默认运行级别的服务程序完成系统引导,如果/etc/inittab误删除或修改错误,Linux将无法正常启动,如图7所示。此时,只有通过救援模式才可以解决此类问题。

/etc/inittab文件丢失引导错误示例

1、有备份文件的恢复办法进入救援模式,执行chroot命令后,如果有此文件的备份(强烈建议系统中的重要数据目录,如/etc、/boot等要进行备份),直接将备份文件拷贝回去,退出重启即可。如果是配置文件修改错误,如比较典型的/boot/grub/grub.conf及/etc/passwd的文件修改错误,也可以直接修正恢复。假设有备份文件/etc/inittab.bak,则在救援模式下执行:

sh-3.1# chroot /mnt/sysimage
sh-3.1# cp /etc/inittab.bak /etc/inittab

2、没有备份文件的恢复办法如果一些配置文件丢失或软件误删除,且无备份,可以通过重新安装软件包来恢复,首先查找到/etc/inittab属于哪一个RPM包(即便文件丢失,因为存在RPM数据库,一样可以查找到结果):sh-3.1# chroot /mnt/sysimage sh-3.1# rpm -qf /etc/inittab initscripts-8.45.3-1

退出chroot模式:

sh-3.1# exit

挂载存放RPM包的安装光盘(在救援模式下,光盘通常挂载在/mnt/source目录下):

sh-3.1# mount /dev/hdc /mnt/source

Fedora系统的RPM包存放在光盘Fedora/RPMS目录下,其他Linux存放位置大同小异,我在这里不一一列举;另外,因为要修复的硬盘系统的根目录在/mnt/sysimage下,需要使用——root选项指定其位置。覆盖安装/etc/inittab文件所在的RPM包:

sh-3.1# rpm -ivh ——replacepkgs ——root /mnt/sysimage /mnt/source/Fedora/RPMS/ initscripts-8.45.3-1.i386.rpm

其中的rpm命令选项“——replacepkgs”表示覆盖安装,执行完成后,即已经恢复了此文件。

如果想只提取RPM包中的/etc/inittab文件进行恢复,可以在进入救援模式后,执行命令:

sh-3.1# rpm2cpio /mnt/source/Fedora/RPMS/initscripts-8.45.3-1.i386.rpm | cpio -idv ./etc/inittab
sh-3.1# cp etc/inittab /mnt/sysimage/etc

注意此命令执行时不能将文件直接恢复至/etc目录,只能提取到当前目录下,且恢复的文件名称所在路径要写完整的绝对路径。提取文件成功后,将其复制到根分区所在的/mnt/sysimage目录下相应位置即可。

救援模式是维护Linux的有力武器,本文以上述两个例子讲解了它的应用方法,希望能够给读者一点启示。解决Linux系统启动的故障,必须充分理解Linux的引导过程,才能够对故障进行有效的判断和处理。

3
5
分享到:
评论

相关推荐

    Linux常见故障的紧急处理方法

    ### Linux常见故障的紧急处理方法 #### 一、概述 在日常使用Linux系统的过程中,难免会遇到各种各样的故障问题。对于这些常见的故障,掌握一些紧急处理方法是十分必要的。本文将详细介绍几种常见的Linux系统故障...

    对Linux几种常见故障的快速处理方法.pdf

    "Linux故障快速处理方法" 本文档主要介绍了 Linux 操作系统中常见故障的快速处理方法。...这些知识点涵盖了 Linux 系统中的一些常见故障的解决方法,为 Linux 系统管理员和使用者提供了有价值的参考。

    Linux系统故障诊断与排除--James Kirkland

    ### Linux系统故障诊断与排除——James ...通过上述内容,我们深入了解了Linux系统启动过程中的关键技术和故障排除方法。接下来的章节将继续探讨其他方面的故障诊断与排除技巧,帮助读者更好地维护和管理Linux系统。

    常见Linux系统故障与解决方法.doc

    【Linux系统故障与解决方法】 Linux系统,如同Windows系统,可能会遇到各种问题和故障,但这些问题并不应该成为新手学习Linux的障碍。相反,通过解决这些问题,我们可以深化对系统的理解,提高故障排查能力。处理...

    Linux故障排查方法

    本文将详细介绍几种常见的Linux故障排查方法和性能调优策略。 首先,当遇到Linux系统异常重启的情况,我们首先要进行的是物理机检查。这包括确认是否有带外事件,比如电源波动、硬件故障,以及检查CPU温度是否过高...

    Linux 系统管理员故障排除手册

    - **备份方法**:介绍几种常见的备份方式,如使用tar命令进行文件备份、利用rsync进行增量备份以及使用专门的备份软件。 #### 四、创建救援CD - **制作救援介质**:为了应对无法从硬盘启动的情况,本章详细介绍了...

    UNIX下几种常见系统故障和解决办法

    解决这些问题所使用的工具主要是安装好系统时创建的应急系统启动盘,关于应急盘的做法,有很多文章都有介绍,可以参见《中国金融电脑》2001年第10期《unix系统超级...下面就几个典型常见的故障提示逐一说明解决办法。

    解决Linux DNS故障.pdf

    "解决Linux DNS故障.pdf" 本文档提供了Linux DNS故障的解决方案。DNS(Domain Name System)是互联网中的一种服务,负责将域名转换为IP地址。Linux系统中,DNS服务通常使用BIND(Berkeley Internet Name Domain)...

    Linux系统启动故障排除.pdf

    本文将详细解析几个常见的Linux启动故障及其修复方法,旨在帮助读者掌握故障排查技巧。 首先,救援模式(Rescue Mode)是Linux在系统启动遇到问题时的一种实用模式。它仅启动必要的服务,通常需要8个核心服务,允许...

    HP Proliant Gen9服务器故障排除指南

    远程故障排除部分介绍了几种不同的工具和服务,比如HP iLO(Integrated Lights-Out)、Virtual Connect Manager以及Onboard Administrator等。这些工具可以帮助IT管理人员在不直接接触服务器的情况下,诊断问题并...

    linux开机grub终极解决方法

    ### Linux开机GRUB终极解决方法详解 #### 一、引言 在Linux系统中,GRUB(GRand Unified Bootloader)作为默认的启动管理器,负责处理系统的启动流程。一旦GRUB出现问题,最常见的症状就是在启动时出现“grub>”...

    Linux命令大全和部分疑难问题的解决方法

    在Linux中,有几种常见的基本命令: 1. **logout**:用于注销当前用户,返回登录界面。 2. **shutdown**:执行关机或重启操作。`-h now`立即关机,`+分钟数`表示分钟后关机,`时间`指设定时间关机,`-r`参数则表示...

    用蓝点Linux排除C盘故障一例.pdf

    8. **Linux解决方案**:虽然文档标题提到"用蓝点Linux排除C盘故障",但具体如何使用Linux来解决这个问题并没有在提供的内容中详细描述。通常,Linux可以作为一个救援系统来访问和修复Windows分区,比如通过Live CD/...

    linux 启动不了,解决方法几乎万能

    本文将详细介绍几种常见的Linux系统启动失败的原因及相应的解决方法,帮助用户快速诊断问题并恢复系统功能。 #### Linux系统无法启动的原因分析 在尝试解决问题之前,首先要了解可能导致Linux系统无法启动的一些...

    Red Hat Enterprise Linux Troubleshooting Guide

    故障排除最佳实践章节中,作者介绍了故障排除的几种基本风格,包括数据收集者、受过教育的猜测者、以及适配者。每种风格各有优劣,选择合适的方法可以帮助更高效地处理问题。此外,本章节还提供了处理问题声明、提出...

    NetBackup 故障排除手册

    - **解决安装问题**:讨论了常见的安装失败情况,例如权限不足、依赖项缺失等问题,并提供了解决方法。 - **解决常见配置问题**:介绍了如何处理配置不当导致的问题,比如端口冲突、不正确的路径设置等。 - **常规...

    Linux实用学习教程

    #### 六、Linux故障排除 - **打印机无法在Linux下工作** - 提供了诊断和解决问题的方法,包括检查驱动、设置权限等步骤。 - **配置声卡遇到的问题** - 解决了在Linux下配置声卡时可能遇到的常见问题,如驱动不兼容...

    linux系统运维.pdf

    8. 故障排除与安全:Linux系统运维还需要具备故障排除技能,以及了解如何进行系统安全加固,防止未经授权的访问和系统漏洞。 以上知识点是由给定文件内容推断出的,由于文档内容可能由于OCR技术问题导致部分文字...

    借助sniffer诊断linux网络故障.docx

    在Linux平台下,有几种常见的嗅探器工具,如Tcpdump、Ethereal(现在称为Wireshark)和EtherApe,它们各自具有独特的功能和优势: 1. **Tcpdump**:Tcpdump是一款命令行工具,虽然没有图形界面,但非常强大且灵活。...

Global site tag (gtag.js) - Google Analytics