Linux启动故障处理

Linux启动故障处理,第1张

【摘要】

当Linux系统出现故障无法正常启动系统时,Linux准备了单用户模式、救援模式等方式可以让我们有效的处理这类问题。本文简单分享一个利用救援模式解决Redhat系统无法启动的案例。

【正文】

一、   问题背景

1)    问题描述

一台部署了RHEL 7.2的物理服务器,突发死机故障,在尝试重启时,发现服务器无法正常进入 *** 作系统,直接进入emergency mode。本文主要分享 *** 作系统启动异常的问题排查过程。(服务器死机据后续日志分析,确定为内核的bug所致,本文不进行累述)

2)   故障现象

系统启动后,提示无法找到/dev/mapper/rhel-root,并直接进入emergency mode。

二、   排查思路

1)    收集系统启动异常的相关提示信息,获取到问题关键点:

Warning:/dev/rhel/root does not exist

初步定为配置文件问题或者逻辑卷root本身问题;

2)    尝试在应急模式下检查逻辑卷状态,发现当前情况并不稳定,常用命令无法使用、显示多为乱码;

3)    尝试进入单用户模式,发现情况和应急模式一样;

Redhat 7.2进入单用户模式:

1、开机启动至内核选择界面,选择第一项,按e进行编辑

2、定位到linux16这一行,找到ro,修改其为rw init=/sysroot/bin/sh

3、按ctrl+X启动至单用户模式

4)    利用系统安装光盘,进入Linux救援模式,进行排查。

Redhat 7.2救援模式启动方法:

1、把光盘加入光驱,然后启动,以光盘进行引导,选择救援模式(中间具体的步骤不再细说)

2、文件系统挂载到/mnt/sysimage目录下,这时切换到此目录下使用chroot /mnt/sysimage这条命令即可

5)    在救援模式下,首先查看服务器lv的情况,发现所有lv

status均为未激活状态。

查看lv

#Lvdisplay

修改lv

#vgchange -a y /dev/docker/root

6)    在尝试修改root的lv status时,发现root所在的vg名和启动时所指定的vg名不一致,基本确定问题点;

7)    修复

l  编辑文件/etc/default/grub

l  修改此文件中GRUB_CMDLINE_LINUX一行中rd.lvm.lv为合适的值

l  再执行以下命令重做grub :

n UEFI: grub2-mkconfig -o /boot/efi/EFI/redhat/grub.cfg

n  非UEFI:grub2-mkconfig -o /boot/grub2/grub.cfg

l  查看文件grub.cfg中是否修改为rd.lvm.lv=rhel/root

l  修改/etc/grub2.cfg中root=后接的lv路径改为实际的路径。

8)    系统启动后,通过history日志,确定为该系统业务部署时,使用了vgrename命令修改了vg名。

三、   总结

对于Linux的问题处理,需要对Linux的运行原理有所理解,这此前提下才能根据有限的提示信息判断问题方向、确定排查范围、找到解决方法。同时,提醒各位初学linux的同事么,在进行linux的一些 *** 作时,需要充分考虑这些 *** 作可能造成的影响,避免类似上述的问题发生。

转自 嘉为教育-rhce认证_rhce培训_linux培训_linux认证_linux考证

Linux系统启动过程如下:

initramfs镜像用来启动系统,解压后是一个临时的根目录。

用file查看initramfs-2.6.32-696.el6.i686.img的文件类型为gzip压缩文件,将它改为gz格式,解压缩。

解压后得到一个initramfs-2.6.32-696.el6.i686.img,查看文件类型为ASCII,继续解压。

grub允许用户可以在 计算机 内同时拥有多个 *** 作系统,并在计算机启动时选择希望运行的 *** 作系统。grub中分区含义如表所示

grub配置文件/etc/grub/grub.conf

参数含义

按e进入命令编辑模式

光标移到kernel行,按e进入grub界面

在quiet后加1,进入单用户模式

按b启动,进入单用户模式(可修改root密码)

eg:假设启动文件/etc/inittab文件被修改,如何修复?

我将inittab文件修改,将默认启动级别改为6,这样系统启动时会一直重启

在单用户模式下修改/etc/inittab文件。

重启后成功。

ps:后来我用的debian虚拟机忘记了密码,尝试后发现它进入单用户的模式有点不一样,记录一下

按e进入编辑模式

在这一行quiet之后添加“init=/bin/bash”,可进入单用户模式

进入后发现修改密码出错,将根目录重新挂载后成功修改密码

为防止外人进入单用户模式修改root密码,可将grub进行加密

加密过程如下

此时,需要按下grub的密码才可以进入编辑模式

如果密码输错,将不能进行编辑

正确输入密码,可以看到跟加密前一样的编辑页面。

首先查询内核是否支持分辨率修改

分辨率参数如下

如果想将分辨率设为1024*768,则写入/boot/grub/grub.conf内,vga=791。

重启后生效

插入光盘,启动时快速按F2键(或者右键点击虚拟机-电源-启动时进入bios)。

进入bios后,将光盘启动移到第一项(+)。

进入光盘修复模式,将光标移动到第三行

一路默认,网络可不设置

a、清除grub密码步骤

b、重要文件找回步骤

eg:将/etc/inittab文件删除,如何恢复?

<1>.进入光盘救援模式,后,将刚刚拷贝在/tmp下的inittab文件复制粘贴到/etc下

<2>.先查询出inittab文件的安装包版本,进入光盘救援模式后,将光盘挂载,从光盘的Packeges目录里安装inittab。

除了检查本机防火墙和云控制台安全组之外,可以通过 telnet 去连接

运行命令 tailf /var/log/messages

当linux服务启动失败的时候,系统会提示我们使用 journalctl -xe 命令来查询详细信息,定位服务不能启动的原因。

mod_evasive是Apache防御攻击的模块,有助于防止DoS、DDoS以及对Apache服务器的暴力攻击。它可以在攻击期间提供规避行动,并通过电子邮件和系统日志工具报告滥用行为。该模块的工作原理是创建一个IP地址和URI的内部动态表,并拒绝以下任何一个IP地址:

如果满足上述任何条件,则发送403响应并记录IP地址。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/5912438.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-08
下一篇2023-03-08

发表评论

登录后才能评论

评论列表(0条)

    保存