0

0

Linux rcu_nocbs 与 rcu_nocb_poll 的无回调核优化经验

冷炫風刃

冷炫風刃

发布时间:2026-02-22 18:40:03

|

188人浏览过

|

来源于php中文网

原创

必须启用config_rcu_nocb_cpu=y编译内核,rcu_nocbs=2,4-6才生效;需配合nohz_full和isolcpus实现零干扰;rcu_nocb_poll以轮询换唤醒抖动,但增cpu开销。

linux rcu_nocbs 与 rcu_nocb_poll 的无回调核优化经验

rcu_nocbs 怎么配才真正起效

不加 CONFIG_RCU_NOCB_CPU=y 编译内核,rcu_nocbs 参数完全无效——这是最常被忽略的前提。很多用户加了启动参数却看不到 rcuo 线程,根源就在这儿。

  • 必须在内核配置中启用 CONFIG_RCU_NOCB_CPU(不是模块,得设为 y
  • rcu_nocbs=2,4-6 表示 CPU 2、4、5、6 不再执行 RCU 回调,所有回调转交对应 rcuob/2rcuop/4 等 kthread 处理
  • 不能只写 rcu_nocbs 而不指定 CPU 列表,否则参数被忽略(内核日志里会打印 rcu_nocbs: no CPUs specified
  • 该设置是静态的:启动后无法增删 CPU,/sys/kernel/debug/rcu/nocb 下也无运行时接口

rcu_nocb_poll 是省唤醒还是烧 CPU

rcu_nocb_poll 的本质是让 rcuo* 线程放弃等待信号,改用轮询方式主动扫回调队列。它不降低延迟,而是把“唤醒延迟”换成“轮询开销”。

  • 开启后,rcuo* 线程默认以约 1ms 周期轮询(可通过 /proc/sys/kernel/rcu_nocb_poll 查看状态)
  • 好处:卸载核上彻底消除唤醒抖动,对 SCHED_FIFO 实时线程更友好
  • 代价:每个 rcuo* 线程持续占用一个调度实体,即使空闲也消耗 CPU 时间片,功耗上升明显
  • 电池设备或高密度部署场景慎用;服务器类低延迟系统可考虑,但建议搭配 isolcpusrcuo* 绑定到非隔离核上

为什么 rcu_nocbs 和 nohz_full 必须配对使用

单独用 rcu_nocbs 只卸载回调,但定时器滴答(tick)还在跑——这意味着该 CPU 仍会周期性被中断打断,实时线程照样被干扰。

Wand AI
Wand AI

一个无代码AI平台,帮助组织快速创建基于AI的业务解决方案

下载
  • nohz_full=2,4-6 让这些核进入“全动态无滴答”模式,关掉周期 tick,仅在必要时触发 one-shot timer
  • isolcpus=2,4-6 进一步禁止调度器往这些核上放普通任务,避免负载迁移和缓存污染
  • 三者组合(isolcpus+nohz_full+rcu_nocbs)才能实现真正的“零干扰”执行环境
  • 漏掉任一环,比如只加 rcu_nocbs 不加 nohz_full,你会发现 perf record -e irq:irq_handler_entry 里仍有大量 timer 中断

验证是否生效的三个关键检查点

别只看 ps aux | grep rcuo 有无进程,那只是表面。真正要看的是行为是否符合预期。

  • 确认卸载核已无 RCU 回调执行:cat /sys/kernel/debug/rcu/rcu_node 中对应 CPU 的 qll(queued callbacks)字段应长期为 0,且 gp(grace period)相关计数不增长
  • 检查 rcuo* 线程是否真在干活:ps -o pid,comm,psr,rtprio -L -C "rcuo[bp]/*" 看其绑定 CPU 和实时优先级(通常为 1)
  • 观察卸载核的中断分布:cat /proc/interrupts | grep -E "(CPU2|CPU4|CPU5|CPU6)" 应几乎只有 IPI(如 Rescheduling interrupts),而 Function call interrupts 显著减少

最容易被忽略的是:RCU 宽限期(GP)本身仍需所有 CPU 参与投票,rcu_nocbs 只卸载回调执行,并不豁免宽限期同步。所以即便 CPU 被卸载,它依然要响应 GP 相关 IPI——这点在做超低延迟测量时,可能成为隐藏的 jitter 来源。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

1585

2023.10.19

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

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

463

2025.10.17

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

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

2274

2025.12.29

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

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

40

2026.01.19

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

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

695

2023.08.10

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

494

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

166

2023.10.07

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

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

1520

2023.06.21

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.5万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

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

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