LinuxCPU亲和性配置_taskset使用技巧解析【教程】
发布时间 - 2026-01-08 00:00:00 点击率:次taskset 是用于实时诊断与干预CPU亲和性的工具,非教程式学习工具;查进程绑定CPU应优先用 taskset -cp PID,注意十六进制掩码需转换,多线程需逐个检查TID,启动时绑定优于运行后绑定,掩码允许多核则仍可动态调度,Python可用 os.sched_setaffinity() 更精准控制。
taskset 不是用来“教程式学习”的工具,而是你在遇到真实调度问题时,拿来就用、改完即生效的诊断与干预手段。它不是银弹,但对 CPU 缓存局部性差、线程频繁迁移、或需隔离关键服务的场景,往往立竿见影。
怎么查一个进程当前绑在哪些 CPU 上?
最常用也最容易出错的是只看 taskset -p PID,却忽略它默认输出的是十六进制掩码——比如返回 3f,你得知道这是 6 位二进制 00111111,对应 CPU 0–5 全开;而 0x5 是 0101,只开 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 出的子线程),加上
-a:taskset -ac 0,2 python workload.py
为什么绑了 CPU,top 里还是看到它在跳核?
这是最常被误解的现象:taskset 设置的是 **调度器允许运行的 CPU 集合**,不是“永远钉死某一个核”。只要亲和性掩码里包含多个 CPU,内核仍可在其中动态调度——这是为了负载均衡,不是失效。
- 想彻底固定到单核?掩码只能设一个位,例如
taskset -c 2或taskset 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 更干净。
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() 系统调用的一层薄封装。它的威力不在于多酷炫,而在于足够轻、足够快、足够直接——只要你清楚自己要锁住哪几
个核、为什么锁、以及锁不住时该去看哪条错误信息。
# linux
# python
# 工具
# session
# 为什么
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
php485函数参数是什么意思_php485各参数详细说明【介绍】
Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
如何在IIS中新建站点并配置端口与IP地址?
网站制作企业,网站的banner和导航栏是指什么?
Laravel如何构建RESTful API_Laravel标准化API接口开发指南
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
JavaScript中的标签模板是什么_它如何扩展字符串功能
Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制
非常酷的网站设计制作软件,酷培ai教育官方网站?
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】
如何在橙子建站中快速调整背景颜色?
Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程
Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程
网站制作报价单模板图片,小松挖机官方网站报价?
Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议
Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
php结合redis实现高并发下的抢购、秒杀功能的实例
,在苏州找工作,上哪个网站比较好?
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
如何获取PHP WAP自助建站系统源码?
如何在IIS7上新建站点并设置安全权限?
node.js报错:Cannot find module 'ejs'的解决办法
Laravel如何实现多对多模型关联?(Eloquent教程)
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
公司网站制作需要多少钱,找人做公司网站需要多少钱?
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
Laravel怎么使用Intervention Image库处理图片上传和缩放
网站制作软件免费下载安装,有哪些免费下载的软件网站?
b2c电商网站制作流程,b2c水平综合的电商平台?
Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】
Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】
Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】
js代码实现下拉菜单【推荐】
使用spring连接及操作mongodb3.0实例
Laravel如何实现全文搜索功能?(Scout和Algolia示例)
canvas 画布在主流浏览器中的尺寸限制详细介绍
Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)
新三国志曹操传主线渭水交兵攻略
javascript如何操作浏览器历史记录_怎样实现无刷新导航
做企业网站制作流程,企业网站制作基本流程有哪些?
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
昵图网官网入口 昵图网素材平台官方入口
如何用PHP工具快速搭建高效网站?
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优

