• 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将无法正常启动。此时,只有通过救援模式才可以解决此类问题。/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的引导过程,才能够对故障进行有效的判断和处理。来源:csghjnbj
blog.chinaunix.net/uid-26567710-id-3050269.html点击,更多精彩








小禾




扫一扫下载订阅号助手,用手机发文章

赞赏



长按二维码向我转账


受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。


















已同步到看一看



取消
发送


我知道了








朋友会在“发现-看一看”看到你“在看”的内容
确定













已同步到看一看写下你的想法



最多200字,当前共字
发送







已发送







朋友将在看一看看到
确定



写下你的想法...









取消
发布到看一看
确定




最多200字,当前共字








发送中













微信扫一扫
使用小程序







取消
允许






即将打开一个新页面

取消
允许








确定


社会

  • 超越欲望的人更容易幸福
    智慧引领幸福 智慧引领幸福 - 来自周国平 - / 10:18 1、超越欲望才有幸福 叔本华说:人受欲望支配,欲望不满足就痛苦,满足了就无聊,人生如同钟摆在痛苦和无聊之间摇摆。他的结论是:根本就
    周国平
  • 她会好吗,还是更烂
    在过去的 20 年里,全世界生活在极度贫困状态下的人口是如何变化的? A. 几乎翻倍 B. 保持不变 C. 几乎减半 在过去 100 年间,死于自然灾害的人数是如何变化的? A. 几乎翻倍 B. 保
    二爷鉴书
  • 让“畅想”变成现实,深信服做到了
    撰稿 | 贾贾 编辑 | 图图 我们常说,这个社会需要想象。 但人们往往难以把握“空想”与“畅想”之间的差异,大都只能在短暂且虚幻的乌托邦中飘飘然一阵,而后不得不回到现实,发觉一切没有任何改变。
    安在
  • 2019|川藏+青藏16天大环线拼车招募
    为什么要去西藏 每个人的答案都不一样 这里是摄影家的天堂 是朝拜者的圣地 这里可以挑战自我 还能“治愈疗伤” 这里的蓝天白云 圣洁的雪山 庄严宏伟的建筑 悠久的人文历史 每一个细节都可能会
    骑行西藏
  • 父母抓阄决定谁陪女儿走下去:击垮一个中年人,生场病就够了
    你做我的朗读者 我做你的摆渡人 戳蓝字一键关注 摆渡人 ☾ 每晚21:39 无论你在哪里,请记得打开手机。 -1- 不知道大家是否相信这样一句话:你越弱的时候,生活越会对你露出獠牙。你越强大时候,
    摆渡人
  • Linux 系统故障修复和修复技巧
    我发现Linux系统在启动过程中会出现一些故障,导致系统无法正常启动,我在这里写了几个应用单用户模式、GRUB命令操作、Linux救援模式的故障修复案例帮助大家了解此类问题的解决。 一、单用户模式 L
    高效运维
  • 是谁扼杀了我们的天赋与激情
    张辉 改变自己主创 辉哥奇谭主创 | 布道师 当我在职场竞争中碰的头破血流时,才终于想起:我的人生答案在于向内寻找,我必须围绕自己的优势去努力,找回久违的激情。所以很感谢在35岁那年的深深焦虑
    改变自己
  • “这是我破釜沉舟、众叛亲离的选择”| 往届生考研图鉴
    2019年全国研究生招生调查报告显示,硕士研究生报名连续五年持续上涨,2019年这个数字更是达到290万,较上一年增加53万人。报告同样显示,2018年往届生占比达到45%,接近考研总人数的一半。 相
    三联生活周刊
  • 25岁以后,你更应该逼自己系统性成长
    今天给大家安利一个干货福利,来自圈外商学院的6天免费职场课。 目前只限定300个免费名额,先到先得。我自己学完觉得帮助很多,想要在职场获得系统性成长的朋友,可以先体验看看。 6天体验下来,我发现课
    王路在隐身
  • 不只是秋叶原!这里才是日本宅文化的秘密基地。
    关注知日公众号,「每日福利」开启,参与详情见文末 |今日福利| 《知日・东京就是日本 !》特集赠书 中野百老汇举办的动漫活动的宣传海报 真正意义的宅文化诞生之地?! 说起日本的御宅文化,大多数外
    知日
  • 他给病人拍照,不想让冷漠成为医生的标签
    三年来,江苏南通市通州区中医院心血管内科的姚帅拍摄了 400 多位患者及家属,总计 1 万余张照片,里面大都是些老人。他问肿瘤终末期患者什么是死亡和希望,问小孩什么是悲伤和幸福,问教徒什么是信仰和人生
    人物
  • 全球投资谈:市场略显惊慌,美ETF却迎来70亿美元净流入!
    因为种种原因,《华尔街见闻》App最近暂时歇了,正在进行恢复方面的沟通,基金哥在那里有一款质量和评价不错的ETF课程。现在,本着对用户负责的态度,见闻已经将其从见闻App转入其旗下的见识服务中,请有意
    美股基金策略
  • 鲁迅诗里的斗士是谁,到今天都没人说明白 | 大家
    1 “斗士诚坚共抗流”是鲁迅先生的诗句,在中学时代,它萦绕在心头,始终让我困惑,好像弄懂了,又不太明白。免不了望文生义,作为一名十年动乱时期的中学生,鲁迅的作品,他的杂文和小说,他的旧体诗,是当时难
    大家
  • 爱情遇上“996”:上班族女性如何恋爱?
    人类不止面对大自然时才会觉得渺小。有的时候,在庞大的都市丛林下,也会觉得自身弱矜矜。建筑太过庞大,物质太过高不可攀,这时仰望势必出现。 如果一名女性,在一个大都市里上班,她会时常感到自己不过是这巨大体
    三联生活周刊
  • 父亲决定孩子飞多高,母亲决定孩子飞多远
    父母决定孩子飞多高,飞多远 - 来自十点读书 - / 15:05 文 | 一本叔 · 主播 | 素年锦时 来源:一星期一本书(ID: yer808) 父母是孩子的第一任老师,他们不经意间的一个举动,都
    十点读书
<< 31 32 33 34 35 >>