0

0

Linux系统异常启动排查_常见失败场景说明【教程】

舞夢輝影

舞夢輝影

发布时间:2025-12-30 18:54:09

|

491人浏览过

|

来源于php中文网

原创

Linux启动失败应先查日志和运行级别:GRUB卡住需检查配置或内核参数;“Started Switch Root”后失败多因根分区挂载问题;服务failed需排查依赖和配置;早期日志需启用journald持久化。

linux系统异常启动排查_常见失败场景说明【教程】

Linux系统启动失败时,不要急着重装,绝大多数情况能通过启动日志和运行级别定位到具体环节。

开机卡在GRUB菜单或直接黑屏

这通常不是内核问题,而是GRUB配置损坏或磁盘识别异常。先确认是否能看到GRUB菜单——如果完全无响应,可能是BIOS/UEFI启动顺序错误,或硬盘未被识别;如果能进GRUB但选中启动项后卡住,重点检查grub.cfglinux行的内核参数是否误删了root=或写错设备名(比如把/dev/sda2写成/dev/sdb2)。

临时修复方法:在GRUB菜单按e编辑启动项,找到linux开头那行,在末尾加上systemd.unit=multi-user.target跳过图形界面,再按Ctrl+X启动。进系统后立即执行:

sudo update-grub
sudo grub-install /dev/sda
  • 注意/dev/sda要换成你实际的系统盘,别用lsblk确认清楚
  • UEFI模式下还需挂载/boot/efi并运行sudo grub-install --target=x86_64-efi --efi-directory=/boot/efi --bootloader-id=ubuntu
  • 如果update-grubcannot find a device for / (is /dev mounted?),说明/etc/fstab里某一行UUID已失效,用blkid核对后修正

启动卡在“Started Switch Root”之后

这是initramfs阶段结束、正切换到真实根文件系统的典型位置。失败原因几乎全是根分区无法挂载,常见于:

  • /etc/fstab中某行指定了不存在的设备或错误UUID,导致systemd尝试挂载失败并阻塞
  • 缺少必要内核模块(如ZFS、Btrfs、LVM或加密模块),initramfs没打包进去
  • 根分区文件系统损坏,fsck被跳过或失败

Ctrl+Alt+F2切到tty,登录后检查:

journalctl -b -p err | grep -i "mount\|fsck\|failed"
lsinitrd | grep -E "(zfs|btrfs|dm-crypt|raid)"

若发现缺失模块,重新生成initramfs:

sudo dracut -f --regenerate-all

Debian/Ubuntu系则用:

sudo update-initramfs -u

能进系统但服务大量failed(尤其是networking.servicessh.service

这不是启动流程中断,而是systemd服务依赖链断裂。别只看systemctl status ssh,先跑:

Bika.ai
Bika.ai

打造您的AI智能体员工团队

下载
systemctl list-units --state=failed
systemctl list-dependencies --reverse ssh.service

常见诱因:

  • /etc/network/interfaces语法错误(Debian系)或/etc/systemd/network/下某个.network文件路径拼错
  • systemd-networkdNetworkManager冲突共存,其中一个被mask但没停干净
  • sshd配置里ListenAddress绑定了一个尚未up的IP(比如静态IP配在eth0,但网卡名实际是enp0s3

临时启用网络可手动:

sudo ip link set enp0s3 up
sudo dhclient enp0s3

再查sshd是否监听:sudo ss -tlnp | grep :22

journalctl看不到早期启动日志(比如GRUB之后、login之前)

默认journal只保存本次启动日志,且systemd-journald服务自身可能没起来。必须提前配置持久化:

  • 确保/var/log/journal目录存在且权限为drwxr-sr-x root systemd-journal
  • 修改/etc/systemd/journald.conf,取消注释并设为Storage=persistent
  • 重启journald:sudo systemctl restart systemd-journald

否则只能靠物理串口、kdump或启动时加loglevel=7systemd.log_level=debug参数临时抓屏日志。

最易被忽略的是:很多“启动失败”其实发生在用户会话层面(比如Display Manager反复崩溃、~/.profile语法错误导致bash退出),此时系统早已完成启动,但没人告诉你——得去/var/log/lightdm/journalctl -u gdm里翻。

相关专题

更多
switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

518

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

403

2024.03.13

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1344

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

698

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

293

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

773

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

571

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

544

2023.07.20

桌面文件位置介绍
桌面文件位置介绍

本专题整合了桌面文件相关教程,阅读专题下面的文章了解更多内容。

0

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.2万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号