0

0

LinuxCPU亲和性配置_taskset使用技巧解析【教程】

冷漠man

冷漠man

发布时间:2026-01-08 20:48:03

|

141人浏览过

|

来源于php中文网

原创

taskset 是用于实时诊断与干预CPU亲和性的工具,非教程式学习工具;查进程绑定CPU应优先用 taskset -cp PID,注意十六进制掩码需转换,多线程需逐个检查TID,启动时绑定优于运行后绑定,掩码允许多核则仍可动态调度,Python可用 os.sched_setaffinity() 更精准控制。

linuxcpu亲和性配置_taskset使用技巧解析【教程】

taskset 不是用来“教程式学习”的工具,而是你在遇到真实调度问题时,拿来就用、改完即生效的诊断与干预手段。它不是银弹,但对 CPU 缓存局部性差、线程频繁迁移、或需隔离关键服务的场景,往往立竿见影。

怎么查一个进程当前绑在哪些 CPU 上?

最常用也最容易出错的是只看 taskset -p PID,却忽略它默认输出的是十六进制掩码——比如返回 3f,你得知道这是 6 位二进制 00111111,对应 CPU 0–5 全开;而 0x50101,只开 CPU 0 和 2。

  • 更直观的方式是加 -c 参数:taskset -cp PID,直接显示 0,2-3 这类列表格式
  • 注意:taskset -p 查的是主线程(TID 等于 PID)的亲和性;多线程程序中,其他线程可能有不同设置,需用 ps -T -p PID 找出所有 TID,再逐个查 taskset -p TID
  • 如果返回 “Operation not permitted”,说明该进程启用了 cap_sys_nice 限制,或你非 root 且目标进程不属于你——这不是 bug,是内核安全机制

启动新进程时就绑定 CPU,别等它跑歪了再拉回来

事后绑定(taskset -cp)虽可行,但无法改变已分配的内存页 NUMA 节点、TLB 状态或缓存预热路径。真正要压测、跑实时任务、或做性能基线对比,必须从启动那一刻就固化亲和性。

  • 正确写法:taskset -c 1,3-4 ./myserver --port 8080 —— -c 后紧跟 CPU 列表,再跟命令,顺序不能错
  • 错误写法:taskset -c 1,3-4 --port 8080 ./myserver —— 把参数塞到命令前面,taskset 会把 --port 当作自己的选项报错
  • 若需绑定全部线程(包括后续 fork 出的子线程),加上 -ataskset -ac 0,2 python workload.py

为什么绑了 CPU,top 里还是看到它在跳核?

这是最常被误解的现象:taskset 设置的是 **调度器允许运行的 CPU 集合**,不是“永远钉死某一个核”。只要亲和性掩码里包含多个 CPU,内核仍可在其中动态调度——这是为了负载均衡,不是失效。

  • 想彻底固定到单核?掩码只能设一个位,例如 taskset -c 2taskset 0x4(CPU 2 对应第 3 位,即 2²=4)
  • 想验证是否真生效?用 ps -eo pid,psr,comm | grep myserver,其中 psr 列显示当前实际运行的 CPU 号——连续观察几秒,若始终为 2,说明成功;若在 2 和 3 之间跳,说明亲和性掩码里同时包含了 2 和 3
  • 注意:中断(IRQ)、内核线程、以及其他非用户进程不受你的 taskset 影响,它们的调度独立

Python 用户别绕远路:用 os.sched_setaffinity() 更可控

如果你的程序本身就是 Python 写的,硬套 shell 的 taskset 启动不仅多一层依赖,还难以在运行中动态调整(比如根据负载切核)。直接调系统 API 更干净。

YouWare
YouWare

社区型AI编程平台,支持一键部署和托管

下载
import os
import sys

绑定当前进程到 CPU 0 和 2

os.sched_setaffinity(0, {0, 2})

验证

print("Current affinity:", os.sched_getaffinity(0))

  • os.sched_setaffinity(pid, cpuset)pid=0 表示当前进程,cpuset 是 int 集合(不是字符串!)
  • 该调用会抛 OSError(如权限不足、CPU 不存在),务必 try/catch;失败时不会静默忽略
  • 子进程默认继承亲和性,但若用 subprocess.Popen 并显式设置了 start_new_session=True,可能重置——这点容易漏测

taskset 的本质不是“高级功能”,而是对内核 sched_setaffinity() 系统调用的一层薄封装。它的威力不在于多酷炫,而在于足够轻、足够快、足够直接——只要你清楚自己要锁住哪几个核、为什么锁、以及锁不住时该去看哪条错误信息。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

738

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

634

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

755

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1259

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

577

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

705

2023.08.11

php学习网站大全
php学习网站大全

精选多个优质PHP入门学习网站,涵盖教程、实战与文档,适合零基础到进阶开发者,助你高效掌握PHP编程。

0

2026.01.09

热门下载

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

精品课程

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

共48课时 | 6.8万人学习

Git 教程
Git 教程

共21课时 | 2.5万人学习

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

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