0

0

perf top 显示 [kworker] 高占比的 workqueue 长任务排查

舞姬之光

舞姬之光

发布时间:2026-01-28 19:09:10

|

931人浏览过

|

来源于php中文网

原创

kworker CPU占用高通常源于workqueue任务堆积或阻塞,需用perf record抓栈定位具体回调函数,检查驱动是否耗时过长、自旋等待或错误串行化。

perf top 显示 [kworker] 高占比的 workqueue 长任务排查

perf top 里看到 [kworker] 占比高,先确认是不是 workqueue 延迟问题

perf top 显示 [kworker/u16:3] 或类似名字的符号持续占 CPU 高比例(比如 >20%),不代表内核真在“忙计算”,更可能是某个 workqueue 任务长期得不到调度完成,或反复重入、堆积。这时候 perf top 只是反映了当前 CPU 正在执行 workqueue 的回调函数(如 process_one_workworker_thread),但根源往往在上层驱动或子系统提交了耗时过长、阻塞、或自旋等待的 work。

用 perf record + stack trace 定位具体 work 回调函数

单纯 perf top 看不到调用链上下文,必须抓。运行以下命令捕获 10 秒内所有 kworker 相关的调用栈:

perf record -e 'sched:sched_switch' -g --call-graph dwarf -a sleep 10

然后过滤出 kworker 切换频繁、且栈顶含 work 相关函数的样本:

perf script | awk '/kworker.*process_one_work/ && /function_name|driver_name/ {print}' | head -20

重点关注栈中是否出现:

  • nvme_queue_rq(NVMe 驱动中 work 提交后卡住)
  • usb_submit_urbusb_anchor_urb(USB 子系统 work 阻塞在 URB 提交)
  • drm_atomic_helper_commit_work(GPU DRM 提交原子状态时 work 挂起)
  • 你自己模块里的 queue_work 后紧跟着的回调函数名(如 mydrv_handle_event

检查 workqueue 是否被意外串行化或绑核导致堆积

Linux 中如果某个 workqueue 被创建为 WQ_UNBOUND | WQ_HIGHPRI,但实际回调里调用了 mutex_lockwait_event,就可能造成 worker 线程休眠、无法及时处理队列。更隐蔽的是:该 workqueue 被显式绑定到单个 CPU(alloc_workqueue("xxx", WQ_CPU_INTENSIVE, 1)),而该 CPU 正在被其他高优先级中断或 RT 任务长期霸占——此时 work 积压,perf top 就会持续显示那个 kworker。

Faceswap
Faceswap

免费开源的AI换脸工具

下载

查证方法:

  • /proc/sys/kernel/workqueue/ 下是否有异常队列(部分内核版本不暴露)
  • cat /proc/kmsg | grep -i "workqueue" 搜近期 warning,例如 workqueue: WQ_MEM_RECLAIM is deprecated
  • 检查模块代码里是否对同一 work 反复调用 schedule_work() 而未加锁或去重

验证是否由 softirq 或 RCU callback 溢出间接引发

某些场景下,[kworker] 高占比其实是假象:真正瓶颈是 softirq 处理太久(如网卡 NAPI poll 卡住),导致系统不断唤醒 kworker 来辅助清理(例如 net_rx_action 触发 __napi_schedulequeue_work_on)。这时 perf 栈里能看到 __do_softirqnapi_pollqueue_workprocess_one_work 这条链。

排查建议:

  • 运行 cat /proc/softirqs,对比 NET_RXNET_TX 的计数增长速率
  • perf record -e 'irq:softirq_entry' -g --call-graph dwarf -a sleep 5 看软中断热点
  • 检查是否启用了 net.core.netdev_budget 过小,导致 NAPI poll 循环次数不足、任务被迫下沉到 workqueue

workqueue 本身不慢,但它成了上游压力的“显示器”。真正要调的,往往是那个忘了 cond_resched() 的驱动回调,或者在 atomic 上下文中偷偷调了 msleep() 的人。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

396

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

396

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

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

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

503

2023.08.10

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

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

1395

2023.06.21

如何安装LINUX
如何安装LINUX

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

706

2023.06.29

linux find
linux find

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

295

2023.06.30

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

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

精品课程

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

共48课时 | 8万人学习

Git 教程
Git 教程

共21课时 | 3.1万人学习

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

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