进/线程绑核运行

进/线程绑核运行

我们在做性能摸底的时候需要排除多核处理器间的差异,甚至是频率的影响。有时特定业务为了确定性,甚至会单独划出一个CPU单独供给,那么我们可以怎么让某个进/线程绑定到特定的核心上运行呢?

taskset

如果不侵入式修改代码,我们可以使用 taskset 命令。它可以设置/获取已经运行的进程的亲和性,或者在给定亲和性的情况下拉起一个新进程。亲和性默认使用比特掩码来表示的,0x1表示 CPU #0,也可以使用CPU列表的形式,逗号分隔即可,如 0,5,8-11,它表示CPU #0 #5 #8 #9 #10 #11,同时还支持间隔指定,如 --cpu-list 0-10:2,它表示CPU #0 #2 #4 #6 #8 #10

set or retrieve a process's CPU affinity

shell 复制代码
# 默认行为是指定亲和性的情况下运行一个新进程
taskset mask command [arguments]

# 获取指定pid的亲和性
taskset -p pid

# 设置亲和性
taskset -p mask pid

# 设置的时候如果使用 cpu-list 的形式,则需要带上 -c 选项
taskset -pc cpu-list pid

# --cpu-list 选项只用于指定亲和性的情况下运行一个新进程
taskset --cpu-list cpu-list command

举例

shell 复制代码
$ taskset -p 1
pid 1's current affinity mask: ffff
$ taskset -pc 1
pid 1's current affinity list: 0-15

$ taskset -pc 1 2726
pid 2726's current affinity list: 0,1
pid 2726's new affinity list: 1

修改源码

如果可以侵入式修改源码,那么我们可以使用 sched_setaffinity 系统调用。sched_setaffinity可以将某个进程绑定到一个特定的CPU。

如果是希望绑定线程到某个CPU上运行,可以使用 pthread_setaffinity_np

相关推荐
不羁。。4 小时前
【操作系统安全】任务3:Linux 网络安全实战命令手册
linux·安全·web安全
流烟默6 小时前
编写脚本在Linux下启动、停止SpringBoot工程
linux·spring boot·shell
IT 古月方源7 小时前
Linux 删除 /boot 后 恢复 (多种方法)
linux·运维·服务器
潇然四叶草7 小时前
rk3588 linux的rootfs.img挂载后通过chroot切换根目录安装应用提示空间不足
linux·rootfs·扩容·空间不足
Arbori_262157 小时前
linux 命令 mkdir
linux·运维·服务器
秃小弟7 小时前
在windows中编写的脚本,在linux上运行时报错linux $‘\r‘: command not found
linux·运维·服务器
左直拳8 小时前
C++程序从windows移植到linux后cmake脚本CMakeLists.txt的修改
linux·c++·windows·cmake·cmakelists·移植到linux
所以经济危机就是没有新技术拉动增长了9 小时前
Android 和 Linux 之间关联和区别
android·linux·运维
郭源潮19 小时前
《Linux:动态库动态链接与静态库静态链接》
linux·运维·服务器·c语言
we19a0sen9 小时前
在kali linux中配置hadoop伪分布式
linux·hadoop·分布式