Linux 系统故障排查和解决方法.doc_第1页
Linux 系统故障排查和解决方法.doc_第2页
Linux 系统故障排查和解决方法.doc_第3页
Linux 系统故障排查和解决方法.doc_第4页
Linux 系统故障排查和解决方法.doc_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

Linux 系统故障排查和解决方法 Linux系统在启动过程中会出现一些故障导致系统无法正常启动我在这里写了几个应用单用户模式、GRUB命令操作、Linux救援模式的故障修复案例帮助大家了解此类问题的解决 (一)单用户模式 Linux系统提供了单用户模式(类似Windows安全模式)可以在最小环境中进行系统维护在单用户模式(运行级别1)中Linux引导进入根shell网络被禁用只有少数进程运行单用户模式可以用来修改文件系统损坏、还原配置文件、移动用户数据等 以下列举了几个单用户模式修复系统故障的典型案例: 案例一:root密码忘记 在单用户模式中Linux不需要root密码(RedHat系统不需要root密码但SuSe则需要不同Linux系统稍有差别本文以FedoraCore6为例讲解)这使更改root密码非常容易了解当系统引导进入多用户模式失败时如何进入单用户模式非常重要 1、在系统启动过程中会出现开始界面按任意键进入GRUB菜单选项(若希望以后无此提示直接进入GRUB菜单选项删除配置文件grub.conf中“hiddenmenu”项即可) 2、按“e”键编辑GRUB引导菜单选项按“e”键后的GRUB屏幕通过箭头键下移到kernel行并按“e”键 3、在尾行光标处添加single按回车键返回前一个屏幕按“b”键进行引导则系统自动进入单用户模式如果要改变root密码则执行命令:sh3.1passwdroot 更改成功后执行命令exit退出重启即可 大家可以在单用户模式中去纠正阻止系统正常启动的很多问题比如: 1、禁用可能中止系统运行的服务如禁用Samba服务则执行:sh3.1chkconfigsmboff下次系统引导就不会启动Samba服务了 2、更改系统缺省运行级如果XWindow无法启动或者出现故障可以编辑/etc/inittab文件采用文本方式登录更改initdefault引导级别为3:id:3:initdefault: 案例二:硬盘扇区错乱 在启动过程中最容易遇到的问题就是硬盘可能有坏道或扇区错乱(数据损坏)的情况这种情况多由于异常断电、不正常关机导致 此种问题发生在系统启动的时候屏幕会显示: Pressrootpasswordorctrl+D: 此时输入root密码系统自动进入单用户模式输入: fscky/dev/hda6 (fsck为文件系统检测修复命令“y”设定检测到错误自动修复/dev/hda6为发生错误的硬盘分区请依据具体情况更改此参数) 系统修复完成后用命令“reboot”重新启动即可 案例三、GRUB选项设置错误 “Error15”显示系统无法找到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只是此文件的软链接) titleFedoraCore(2.6.181.2798.fc6) root(hd00) kernel/boot/vmlinuz2.6.181.2798.fc6roroot=LABEL=/rhgbquietinitrd/boot/initrd2.6.181.2798.fc6.img 其中: “title”段指定了GRUB引导的系统: “root”段指定了/boot分区所在的位置: “kernel”段指定了内核文件所在位置内核加载时权限属性为只读(“ro”)以及指定根分区所在位置(root=LABEL=/); “initrd”指定了镜像文件所在位置 所以GRUB在引导时顺序为首先加载/boot分区然后依次载入内核与镜像文件 案例 “titleFedoraCore(2.6.181.2798.fc6)”段被误删除 此时系统启动后会自动进入“GRUB”命令行为排除故障我们可以依次做如下操作: 1、查找/boot/grub/grub.conf文件所在分区GRUBfind/boot/grub/grub.conf(hd00) 2、查看grub.conf文件错误GRUBcat(hd00)/boot/grub/grub.conf建议系统安装设置好后要将grub.conf文件备份如果有备份文件如grub.conf.bak则此时可以查看备份文件与当前文件比较发现错误:GRUBcat(hd00)/boot/grub/grub.conf.bak 3、确认错误后先通过命令行方式完成GRUB引导进入系统后再行修复grub.conf文件错误: 1)指定/boot分区root(hd00) 2)指定内核加载kernel/boot/vmlinuz2.6.181.2798.fc6roroot=LABEL=/rhgbquiet 3)指定镜像文件所在位置initrd/boot/initrd2.6.181.2798.fc6.img 提示:GRUB支持tab键命令补全功能 4、从/boot分区启动boot(hd00) 命令行模式可以在GRUB菜单模式中通过按“c”键调用也可以用于测试新编译的内核(设置kernel、initrd引导新内核及镜像文件)增加对GRUB引导以及Linux系统引导知识的了解将对此类故障排除大有帮助 (三)Linux救援模式应用 当系统连单用户模式都无法进入时或出现GRUB命令行也不能解决的引导问题我们就需要使用Linux救援模式来进行故障排除了 步骤如下: 1、将Linux安装光盘(如果使用CD光盘则放入第一张引导光盘)放入光驱设置固件CMOS/BIOS为光盘引导当Linux安装画面出现后在“boot:”提示符后输入“linuxrescue”回车进入救援模式(想了解救援模式详细信息还可以按F5键查看) 2、系统会检测硬件引导光盘上的Linux环境依次提示你选择救援模式下使用的语言(建议选择默认的英文即可根据笔者测试部分Linux系统选择中文会出现乱码);键盘设置用默认的“us”就好;网络设置可以根据需要大部分故障修复不需要网络连接可不进行此项设置选择“No” 3、接下来系统将试图查找根分区出现挂载提示设置默认在救援模式硬盘的根分区将挂载到光盘Linux环境的/mnt/sysimage目录下默认选项“continue”表示挂载权限为读写:“Readonly”为只读如果出现检测失败可以选择“skip”跳过此处因为要对系统进行修复所以需要有读写权限一般选择默认选项“continue” 进入下一步后系统提示执行“chroot/mnt/sysimage”命令可以将根目录挂载到我们硬盘系统的根目录中去 案例一:双系统启动修复 当我们安装双系统环境先安装Linux再安装Windows;或者已经安装好双系统环境的Windows损坏在重新安装Windows后保存GRUB的MBR(MasterBootRecord主引导记录)会被Windows系统的自举程序NTLDR所覆盖造成Linux系统无法引导 1、如果要恢复双系统引导首先用上述方法进入救援模式执行chroot命令如下:sh3.1chroot/mnt/sysimage 2、将根目录切换到硬盘系统的根目录中然后执行grubinstall命令重新安装GRUB:sh3.1grubinstall/dev/hda“/dev/hda”为硬盘名称如使用SCSI硬盘或Linux安装在第二块IDE硬盘此项设置要做相应调整 3、然后依次执行exit命令退出chroot模式及救援模式(执行两次exit命令):sh3.1exit系统重启后将恢复GRUB引导的双系统启动 案例二:系统配置文件丢失修复 系统在引导期间很重要的一个过程就是init进程读取其配置文件/etc/inittab启动系统基本服务程序及默认运行级别的服务程序完成系统引导如果/etc/inittab误删除或修改错误Linux将无法正常启动此时只有通过救援模式才可以解决此类问题 /etc/inittab文件丢失引导错误示例 1、有备份文件的恢复办法进入救援模式执行chroot命令后如果有此文件的备份(强烈建议系统中的重要数据目录如/etc、/boot等要进行备份)直接将备份文件拷贝回去退出重启即可 如果是配置文件修改错误如比较典型的/boot/grub/grub.conf及/etc/passwd的文件修改错误也可以直接修正恢复 假设有备份文件/etc/inittab.bak则在救援模式下执行:sh3.1chroot/mnt/sysimagesh3.1cp/etc/inittab.bak/etc/inittab 2、没有备份文件的恢复办法如果一些配置文件丢失或软件误删除且无备份可以通过重新安装软件包来恢复 首先查找到/etc/inittab属于一个RPM包(即便文件丢失因为存在RPM数据库一样可以查找到结果): sh3.1chroot/mnt/sysimagesh3.1rpmqf/etc/inittabinitscripts8.45.31 退出chroot模式: sh3.1exit 挂载存放RPM包的安装光盘(在救援模式下光盘通常挂载在/mnt/source目录下): sh3.1mount/dev/hdc/mnt/source Fedora系统的RPM包存放在光盘Fedora/RPMS目录下其他Linux存放位置大同小异我在这里不一一列举; 另外因为要修复的硬盘系统的根目录在/mnt/sysimage下需要使用root选项指定其位置 覆盖安装/etc/inittab文件所在的RPM包: sh3.1rpmivhreplacepkgsroot/mnt/sysimage/mnt/source/Fedora/RPMS/initscripts8.45.31.i386.rpm 其中的rpm命令选项“replacepkgs”表示覆盖安装执行完成后即已经恢复了此文件 如果想只提取RPM包中的/etc/inittab文件进行恢复可以在进入救援模式后执行命令: sh3.1rpm2cpio/mnt/source/Fedora/RPMS/initscripts8.45.31.i386.rpm|cpioidv./etc/inittabsh3.

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论