【linux调试】使用 sysrq 快照内核状态堆栈

使用 sysrq 快照内核状态堆栈

当你发现内核线程 "卡住(hang)" 时,第一步是检查内核线程的运行位置,可以通过 SysRq(系统请求键) 查看 CPU 和任务的堆栈状态。这步不需要加打印,会很轻量。

启用 sysrq 功能:

确保内核支持 SysRq(通常在核心配置里启用 CONFIG_MAGIC_SYSRQ):

echo 1 > /proc/sys/kernel/sysrq

触发所有 CPU 的堆栈快照: 通过以下命令输出所有 CPU 上线程的堆栈状态:

echo w > /proc/sysrq-trigger

echo w 命令输出系统中所有运行中的任务堆栈。

输出中会包含目标内核线程的 堆栈回溯(stack trace),你可以从中判断线程的阻塞点。

定位目标线程:

在生成的日志中,找到卡住的线程。

检查其信号状态(如 TASK_RUNNING, TASK_UNINTERRUPTIBLE)和调用的栈帧。

示例结果 (dmesg):

sysrq: Show Blocked State

task: kthread_example state: TASK_UNINTERRUPTIBLE

Call Trace:

my_function_wait+0x20/0x50

wait_for_event+0x15/0x60

schedule+0x35/0x50

如果线程处于 TASK_UNINTERRUPTIBLE,说明它可能正在等待某些资源。

"函数名" 指向目标函数,比如这里是 my_function_wait,你需要深入分析该函数的实现。

相关推荐
Web极客码4 小时前
2026年Linux VPS安全加固清单:SSH、防火墙与审计就绪配置
运维·服务器·数据库
无敌的黑星星4 小时前
Java8 CompletableFuture 实战指南
linux·前端·python
星恒讯工业路由器5 小时前
配网自动化多网融合应用解决方案
运维·自动化
前端技术5 小时前
03_网络层与IP编址:理解网络寻址的核心逻辑
服务器·网络·php
智慧物业老杨5 小时前
智慧物业收费系统的数智化落地实践:从人工硬扛到自动化闭环
运维·自动化
Championship.23.245 小时前
Linux Top 命令族深度解析与实战指南
java·linux·服务器·top·linux调试
techdashen5 小时前
Cloudflare 为何抛弃 NGINX,用 Rust 自研了一个代理
运维·nginx·rust
南城猿5 小时前
保姆级 Ubuntu 部署 禅道
linux·运维·ubuntu
ITHAOGE156 小时前
下载 | Windows Server 2025官方原版ISO映像!(4月更新、标准版、数据中心版、26100.32690)
服务器·windows·科技·微软·电脑
zhangrelay6 小时前
三分钟云课实践速通--模拟电子技术-模电--SimulIDE
linux·笔记·学习·ubuntu·lubuntu