0

0

Linux怎么开启RPS网络并行_Linux多队列网卡优化配置【高并发】

冰火之心

冰火之心

发布时间:2026-01-25 09:04:03

|

156人浏览过

|

来源于php中文网

原创

应优先启用网卡硬件RSS,再依次配置RPS、RFS、XPS及中断亲和性:1.用ethtool启用多队列;2.为各rx队列设RPS CPU掩码;3.配置RFS流表容量与全局阈值;4.为tx队列设XPS掩码;5.禁用irqbalance并静态绑定中断到对应CPU。

linux怎么开启rps网络并行_linux多队列网卡优化配置【高并发】

一、确认网卡多队列支持并启用硬件RSS

若网卡本身支持硬件多队列(RSS),应优先启用该功能以实现底层流量散列分发,为RPS提供良好基础。硬件RSS可将入站数据包按流哈希分发至不同接收队列,避免单队列瓶颈。

1、执行命令查看当前网卡队列能力:ethtool -l eth0(将eth0替换为实际网卡名,如ens33、enp0s3等)。

2、若输出中“Combined”字段最大值大于1,且当前值为1,则说明硬件支持但未启用多队列。

3、将接收与发送队列数设为CPU物理核心数(例如4核):sudo ethtool -L eth0 combined 4

4、验证设置生效:ls /sys/class/net/eth0/queues/ 应显示 rx-0、rx-1、rx-2、rx-3 等多个接收队列目录。

二、启用RPS实现软件层接收负载分发

RPS在内核网络软中断(NET_RX_SOFTIRQ)阶段,依据数据包特征选择目标CPU进行后续处理,弥补无RSS硬件或队列数不足时的多核利用率缺陷。

1、计算CPU掩码:假设使用前4个CPU核心(编号0–3),十六进制掩码为 f(即二进制1111);若需启用CPU0、CPU2、CPU3,则掩码为 e(1110)。

2、为每个接收队列启用RPS并指定CPU掩码:echo f > /sys/class/net/eth0/queues/rx-0/rps_cpus

3、重复步骤2,依次配置其余队列:echo f > /sys/class/net/eth0/queues/rx-1/rps_cpusecho f > /sys/class/net/eth0/queues/rx-2/rps_cpusecho f > /sys/class/net/eth0/queues/rx-3/rps_cpus

4、设置全局RPS流表总条目数(推荐值为CPU数×4096):echo 16384 > /proc/sys/net/core/rps_sock_flow_entries(以4核为例)。

三、配置RFS提升缓存局部性与流一致性

RFS根据应用进程所在CPU及上次处理该流的CPU位置,动态调整RPS目标,减少跨CPU缓存失效,增强L3缓存命中率,特别适用于长连接或高吞吐TCP服务。

1、启用RFS需先确保RPS已开启,然后设置每接收队列的流表容量:echo 4096 > /sys/class/net/eth0/queues/rx-0/rps_flow_cnt

2、对所有rx-*队列重复执行:echo 4096 > /sys/class/net/eth0/queues/rx-1/rps_flow_cntecho 4096 > /sys/class/net/eth0/queues/rx-2/rps_flow_cntecho 4096 > /sys/class/net/eth0/queues/rx-3/rps_flow_cnt

3、启用全局RFS开关(需内核CONFIG_RFS_ENABLED=y):echo 1 > /proc/sys/net/core/netdev_rfs_threshold

四、绑定XPS优化发送路径CPU亲和性

XPS控制数据包从协议栈发出时使用的发送队列所绑定的CPU,避免tx队列跨核访问导致锁竞争与cache line bouncing,与RPS形成收发双向协同。

1、检查发送队列是否存在:ls /sys/class/net/eth0/queues/ | grep tx-

2、为每个tx-*队列设置XPS CPU掩码(与对应rx队列保持一致):echo f > /sys/class/net/eth0/queues/tx-0/xps_cpus

3、若存在tx-1、tx-2等,同样执行:echo f > /sys/class/net/eth0/queues/tx-1/xps_cpusecho f > /sys/class/net/eth0/queues/tx-2/xps_cpus

五、禁用irqbalance并手动绑定中断亲和性

irqbalance服务会动态迁移网卡中断,可能破坏RPS/XPS所需的稳定CPU映射关系。在高并发场景下,应停用该服务并静态绑定各队列中断到专用CPU。

1、停止并禁用irqbalance:sudo systemctl stop irqbalance && sudo systemctl disable irqbalance

2、查找网卡中断号:cat /proc/interrupts | grep eth0,识别形如“eth0-rx-0”、“eth0-rx-1”的行及其左侧数字(如45、46)。

3、将中断45绑定至CPU0:echo 1 | sudo tee /proc/irq/45/smp_affinity

4、将中断46绑定至CPU1:echo 2 | sudo tee /proc/irq/46/smp_affinity

5、依此类推,使rx-0→CPU0、rx-1→CPU1、rx-2→CPU2、rx-3→CPU3,确保中断与RPS目标CPU严格对齐。

相关专题

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

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

394

2023.07.18

堆和栈区别
堆和栈区别

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

574

2023.08.10

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

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

468

2024.01.03

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

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

13

2025.12.06

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

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

1373

2023.06.21

如何安装LINUX
如何安装LINUX

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

705

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

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

777

2023.07.05

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.23

热门下载

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

精品课程

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

共48课时 | 7.7万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

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

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