0

0

perf top 实时显示 [kworker] 或 [ksoftirqd] 热点时的下一步分析

冷炫風刃

冷炫風刃

发布时间:2026-01-22 13:06:09

|

691人浏览过

|

来源于php中文网

原创

当 perf top 显示 [kworker] 或 [ksoftirqd] 占用高 CPU,表明内核线程正高频处理工作队列或软中断,根源多在驱动、中断负载或内核子系统异常;需通过 ps、perf record -g 结合 /proc/interrupts、/proc/softirqs 及 dmesg 定位具体设备与驱动问题,并采取中断绑定、NAPI 调优等措施验证缓解效果。

perf top 实时显示 [kworker] 或 [ksoftirqd] 热点时的下一步分析

perf top 实时显示 [kworker][ksoftirqd] 占用显著 CPU 时,说明内核线程正在高频处理工作队列或软中断任务,这通常指向底层驱动、中断负载或内核子系统异常,而非用户程序问题。下一步分析需聚焦内核行为本身,而非盲目优化应用代码。

确认具体内核线程类型与上下文

先区分是通用工作队列(kworker/u*:*)、绑定 CPU 的工作队列(kworker/0:*),还是软中断线程(ksoftirqd/0):

  • 运行 ps -eLf | grep -E "(kworker|ksoftirqd)" 查看完整线程名和 CPU 绑定情况
  • 配合 perf top -p $(pgrep -f "ksoftirqd/0") 单独监控某一个软中断线程的热点函数
  • 注意线程名末尾的数字(如 kworker/0:2H 中的 H 表示 high-priority workqueue)

启用调用图并定位触发源头

仅看函数名(如 __do_softirqprocess_one_work)不够,必须回溯到谁提交了这些 work 或触发了软中断:

如此AI员工
如此AI员工

国内首个全链路营销获客AI Agent

下载
  • perf record -g -e irq:softirq_entry -a sleep 5 捕获软中断入口,再用 perf report --no-children 查看调用链
  • 对工作队列:运行 perf record -g -e sched:sched_wakeup -C 0 --filter-pid=$(pgrep kworker/0) sleep 5,观察是谁唤醒了该 kworker
  • 若看到大量 nvme_irqigb_pollahci_port_intr 等驱动函数,说明对应设备产生高频率中断或 NAPI 轮询压力

关联硬件与驱动状态验证假设

多数 kworker/ksoftirqd 高负载由硬件行为引发,需交叉验证:

  • 检查中断分布:cat /proc/interrupts | head -20,关注某 CPU 上中断计数是否远高于其他 CPU(尤其网卡、NVMe、USB 控制器)
  • 查看软中断统计:cat /proc/softirqs,若 NET_RXTIMER 列数值每秒增长极快,说明网络收包或定时器调度过载
  • 排查驱动问题:例如 dmesg | grep -i "error\|warn\|throttle" 是否有网卡丢包重传、NVMe reset、USB reset 等日志

针对性缓解与验证手段

确认根源后,可尝试轻量级干预并快速验证效果:

  • 调整网卡 NAPI 权重:echo 64 > /sys/class/net/eth0/napi_defer_hard_irqs(部分驱动支持)
  • 绑定中断到特定 CPU:echo 1 > /proc/irq/XX/smp_affinity_list,避免单核被打满
  • 临时关闭非必要服务(如蓝牙、USB gadget、IPv6 router advertisement)观察 kworker 是否回落
  • 升级固件或内核补丁(如已知某版本 igb 驱动在多队列下导致 workqueue 积压)

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

188

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

288

2023.10.25

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

466

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

13

2025.12.06

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

482

2023.08.10

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

38

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

18

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

234

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

61

2026.01.21

热门下载

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

精品课程

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

共137课时 | 9.1万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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