Linux查看进程中断,pidstat -u 5使用详解
时间:2026-05-19 16:39:37 263浏览 收藏
本文澄清了一个常见误区:`pidstat -u 5` 并不能用于查看或分析系统中断,它仅统计进程在用户态和内核态的CPU时间消耗(%usr/%system),而中断(IRQ/softirq)属于内核中断子系统的底层行为,与进程级统计不在同一抽象层面;若需诊断中断相关问题——如某进程是否引发网卡硬中断飙升或软中断压垮ksoftirqd——必须转向`/proc/interrupts`、`/proc/softirqs`或`perf`等内核级工具,结合中断亲和性、软中断计数变化及中断处理入口追踪进行深度归因。

pidstat -u 5 不能查看系统中断,它只显示进程级 CPU 时间分布(%usr/%system),不涉及中断计数或来源。 真正要查“进程引发的中断”,得换工具——pidstat 本身不采集中断向量、IRQ 或软中断(softirq)数据,这是内核中断子系统层面的事,和进程统计不在同一抽象层。
为什么 pidstat -u 5 不反映中断?
pidstat -u 输出的 %system 是进程在内核态执行的时间总和,包含系统调用、页错误处理、锁竞争等,但不区分是否由硬件中断触发。比如一个进程频繁读磁盘,可能引发大量 I/O 中断,但 pidstat 只看到它占用了高 %system,看不到背后是 ata_piix 还是 nvme 的 IRQ 在猛跳。
pidstat -u 5中的5是采样间隔(秒),不是“每 5 秒一次中断统计”- 它不会输出
INTR、IRQ、softirq、timer等字段 - 即使加
-w(上下文切换)或-d(I/O),也仅间接关联中断,不等于中断本身
真正能看进程相关中断的替代命令
若你怀疑某个进程导致中断飙升(如网卡硬中断被某用户进程绑定、ksoftirqd 被压垮),应组合使用:
/proc/interrupts:查看每个 CPU 上各 IRQ 的累计次数,配合grep锁定设备(如eth0、nvme0),再用cat /proc/irq/*/smp_affinity_list看中断亲和性cat /proc/softirqs:观察NET_RX、NET_TX、HI、TIMER等软中断计数变化,用watch -n 1 'cat /proc/softirqs'对比差值perf record -e irq:irq_handler_entry -g -p $(pgrep -f your_process):只有当你明确想追踪某进程是否触发了特定中断 handler 时才用,但实际中极少直接命中(中断 handler 运行在 softirq 上下文,不属于用户进程)
pidstat -u 5 的真实用途和常见误用
它适合快速定位“谁在吃 CPU”,尤其是区分用户态和内核态开销。例如:
- 看到某 Java 进程
%usr很低、%system接近 100%,说明它卡在系统调用里(如epoll_wait、futex、read),不是中断问题,而是同步阻塞或锁争用 - 若
%system高且伴随pidstat -w中nvcswch/s(非自愿切换)飙升,更可能是 CPU 调度压力大,而非中断本身 - 误以为
pidstat -u 5能替代cat /proc/interrupts—— 它们解决的是完全不同的问题域
真正要归因“进程 → 中断”,必须跳出进程视角,进到中断控制器(APIC/IOAPIC)、驱动 IRQ 处理逻辑、以及软中断调度队列这一层。而 pidstat 停留在 task_struct 统计,连中断栈帧都看不见。
今天关于《Linux查看进程中断,pidstat -u 5使用详解》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于Linux的内容请关注golang学习网公众号!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
263 收藏
-
256 收藏
-
209 收藏
-
135 收藏
-
410 收藏
-
433 收藏
-
497 收藏
-
410 收藏
-
415 收藏
-
366 收藏
-
364 收藏
-
191 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习