0

0

irqbalance 服务失效导致单核 net_rx 打满的 irq affinity 手动绑定方法

舞姬之光

舞姬之光

发布时间:2026-02-04 18:04:41

|

745人浏览过

|

来源于php中文网

原创

irqbalance默认将net_rx中断集中到CPU0,因其节能策略误判高频率网络中断为可迁移,未适配NIC多队列并行需求,导致CPU0软中断过载。

irqbalance 服务失效导致单核 net_rx 打满的 irq affinity 手动绑定方法

irqbalance 为什么会让 net_rx 中断全挤在 CPU0 上

irqbalance 默认策略偏向“节能”和“负载均衡”,但对网络中断这类高频率、低延迟敏感的 irq,它常误判为“可迁移”,把所有 net_rx 类中断(如 eth0-TxRx-0enp3s0f0-TxRx-1)集中调度到 CPU0。这不是 bug,是它的默认权重逻辑没考虑 NIC 多队列的实际并行需求。

现象通常是:top 看到 CPU0 的 si(softirq)持续 90%+,/proc/interrupts 里对应网卡的 Rx 行只在 CPU0 列有计数,其余 CPU 为 0。

  • 确认是否 irqbalance 在运行:systemctl is-active irqbalance
  • 临时停用验证效果:sudo systemctl stop irqbalance(停用后不会自动重绑,需手动操作)
  • 不要直接 kill 进程,否则 systemd 可能重启它

查清网卡支持的中断号和 CPU topology

先得知道要绑哪些中断、能绑到哪些 CPU。现代多队列网卡每队列一个 irq,编号在 /proc/interrupts 中按设备名可识别。

执行:grep -i "eth0\|enp3s0f0" /proc/interrupts(替换成你的实际接口名),输出类似:

125:  124856789  0          0          0   PCI-MSI 122880-edge      eth0-TxRx-0
126:  987654321  0          0          0   PCI-MSI 122881-edge      eth0-TxRx-1
127:  876543210  0          0          0   PCI-MSI 122882-edge      eth0-TxRx-2

其中第一列 125126127 是中断号;后续四列是各 CPU(0–3)上的触发次数。

  • lscpu | grep "CPU\(s\)" 确认物理 CPU 数和超线程情况
  • 若启用了超线程(HT),通常建议将不同 irq 绑定到不同物理核(如 CPU0/CPU2/CPU4…),避免同核双线程争抢
  • 避免绑定到隔离核(isolcpus)或用于 real-time 任务的 CPU,除非你明确控制了调度域

手动写入 smp_affinity_list 绑定 irq 到指定 CPU

Linux 内核 4.15+ 推荐用 smp_affinity_list(十进制 CPU 编号列表),比老式十六进制 smp_affinity 更直观、不易出错。

例如把 irq 125 绑到 CPU2,irq 126 绑到 CPU3,执行:

魔术橡皮擦
魔术橡皮擦

智能擦除、填补背景内容

下载
echo 2 | sudo tee /proc/irq/125/smp_affinity_list
echo 3 | sudo tee /proc/irq/126/smp_affinity_list
echo 4 | sudo tee /proc/irq/127/smp_affinity_list

验证是否生效:cat /proc/irq/125/smp_affinity_list 应返回 2;再看 /proc/interrupts 对应行,几秒后 CPU2 列计数应开始增长。

  • 必须用 echo + tee,直接重定向(sudo echo 2 > /proc/irq/125/smp_affinity_list)会因权限问题失败
  • 绑定后中断不会立刻切换,需等下一个数据包触发;可发 ping 或 curl 触发流量观察
  • 该设置重启即失效,需持久化(见下一条)

开机自动绑定:用 systemd service 替代 irqbalance 或 patch udev rule

最稳妥的方式是禁用 irqbalance,并用 systemd service 在网卡 up 后执行绑定。不推荐改 udev rule(易与 NetworkManager 冲突)。

新建 /etc/systemd/system/net-irq-affinity.service

[Unit]
Description=Set IRQ affinity for network queues
After=network.target
Wants=network.target

[Service]
Type=oneshot
ExecStart=/bin/sh -c 'for irq in $(grep -l "eth0-TxRx" /proc/irq/*/chip 2>/dev/null | cut -d/ -f4); do echo $((irq % 4 + 2)) | tee /proc/irq/$irq/smp_affinity_list 2>/dev/null; done'
RemainAfterExit=yes

[Install]
WantedBy=multi-user.target

说明:$((irq % 4 + 2)) 是个简单轮转逻辑(适配 4 核),你应根据实际 CPU 数和拓扑替换为明确编号,比如 echo 2 > /proc/irq/125/smp_affinity_list 这样逐行写死更可靠。

  • 启用服务:sudo systemctl daemon-reload && sudo systemctl enable --now net-irq-affinity.service
  • 务必先 sudo systemctl disable irqbalance,否则它可能在 service 启动后又覆盖绑定
  • 如果使用 DPDK 或 kernel bypass 方案,还需检查 /sys/class/net/eth0/device/msi_irqs/ 下的映射关系,部分驱动需要额外禁用 MSI-X auto-mask

真正麻烦的不是绑定动作本身,而是网卡驱动是否如实暴露多队列、BIOS 是否开启 VT-d/ACS、以及 PCIe AER 错误会不会导致某队列 irq 静默失效——这些都可能让看似正确的 affinity 设置毫无效果。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

445

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

178

2023.10.30

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1256

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

275

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2195

2025.12.29

java接口相关教程
java接口相关教程

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

33

2026.01.19

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

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

533

2024.01.03

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

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

17

2025.12.06

抖音网页版入口与视频观看指南 抖音官网视频在线访问
抖音网页版入口与视频观看指南 抖音官网视频在线访问

本专题汇总了抖音网页版的入口链接、官方登录页面以及视频观看入口,帮助用户快速访问抖音网页版,提供免登录访问方式和直接进入视频播放页面的方法,确保顺利浏览和观看抖音视频。

61

2026.02.04

热门下载

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

精品课程

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

共48课时 | 8.4万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

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

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