linux cpu亲和性核心是精准稳定绑定进程/线程至指定cpu以降调度开销、提缓存命中率;常用taskset临时绑定,systemd持久化配置,c/c++代码级细粒度控制,并需结合lscpu等工具依硬件拓扑合理分配。

Linux CPU亲和性不是“能不能绑”,而是“怎么绑得准、用得稳”。核心在于让进程或线程固定运行在指定CPU上,减少跨核调度开销、提升缓存命中率,尤其对低延迟服务(如网络发包、实时计算、GPU协同任务)效果明显。
一、用 taskset 快速绑定(最常用)
taskset 是用户态最直接的工具,适合调试、临时部署或启动时指定:
- 查看某进程当前亲和掩码:
taskset -p 1234→ 输出类似pid 1234's current affinity mask: 0xff(十六进制,每位对应一个逻辑CPU) - 启动时绑定到 CPU 2:
taskset -c 2 ./server - 运行中绑定到 CPU 0 和 3:
taskset -pc 0,3 1234 - 支持范围与步长写法:
taskset -c 0-3,6,8-10:2表示 CPU 0/1/2/3/6/8/10
二、通过 systemd 持久化配置(生产推荐)
服务长期运行时,用 systemd 单元文件设置更可靠,重启不失效:
- 编辑服务文件(如
/etc/systemd/system/myapp.service) - 在
[Service]块中添加:CPUAffinity=1 3 5或CPUAffinity=0-3(空格分隔,不支持逗号) - 多个
CPUAffinity=行会被合并(逻辑 OR),例如:CPUAffinity=0 1CPUAffinity=2 3
等效于允许在 CPU 0/1/2/3 上运行 - 生效命令:
sudo systemctl daemon-reload && sudo systemctl restart myapp
三、用 C/C++ 代码级控制(高精度场景)
需要细粒度控制线程级亲和性(比如每个工作线程绑不同核),直接调用系统 API:
- 头文件:
#include <sched.h></sched.h> - 关键函数:
sched_setaffinity(0, sizeof(cpu_set_t), &cpuset)(0 表示当前线程) - 典型流程:
cpu_set_t cpuset;CPU_ZERO(&cpuset);CPU_SET(2, &cpuset); // 绑定到 CPU 2sched_setaffinity(0, sizeof(cpuset), &cpuset); - 注意:需检查返回值,权限不足(如非 root 绑定隔离核)会失败
四、结合硬件拓扑做合理绑定(避免踩坑)
盲目绑定可能适得其反。先看清物理结构再操作:
- 查逻辑CPU编号与物理关系:
lscpu或cat /proc/cpuinfo | grep -E "processor|core id|physical id" - NUMA 系统中,优先将进程与本地内存、网卡队列、GPU 所在 NUMA 节点对齐
- 超线程(HT)下,同物理核的两个逻辑核(如 CPU 0/1)共享缓存,高吞吐服务建议错开绑定(如用 0/2/4… 而非 0/1/2)
- 预留至少 1–2 个 CPU 给系统中断(IRQ)、ksoftirqd、sshd 等,避免绑死导致系统响应迟滞










