【调试工具】taskset 设置处理器的亲和度

一、功能介绍

taskset命令用于设置进程(或 线程)的处理器亲和性(Processor Affinity),可以将进程(或 线程)绑定到特定的一个 或 多个CPU上去执行,而不允许将进程(或 线程)调度到其他的CPU上。


二、用户进程使用

1.编写测试程序

c 复制代码
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char **argv)
{
    char *env;

    env = getenv("PATH");
    
    printf("PATH: %s\n", env);
    
    while(1);
    
   return 0;
}

2.查看进程 输出结构处理器亲和性掩码是f,表示进程(或线程)可以在Host上让任何一个CPU运行。查看进程(或 线程)允许允许CPU范围使用-c参数。 cpu核心数为4,分别为cpu0、cpu1、cpu2、cpu3

3.查看当前在运行在哪个cpu上

pidstat -p 2778

可以看到当前是在cpu0上运行。

4.绑定到其它单个cpu

taskset -p 01 2778   // 绑定到 cpu 1

taskset -p 02 2778  // 绑定到 cpu2

5.绑定CPU亲和性指定一组范围

taskset -pc 1,2,3,4 pid  // -c指定cpu 1 2 3 4 taskset -p 0x7 pid    // 0x7 -- 0111, 指定cpu 1 2 3


三、内核线程使用

内核中是调用 set_cpus_allowed_ptr 函数去实现的,示例如下:

c 复制代码
#include<linux/kernel.h>
#include<linux/module.h>
#include<linux/kthread.h>
 
struct task_struct *task0;
static spinlock_t spinlock;
int val;
 
int task(void *arg)
{
    printk(KERN_INFO "%s:%d\n",__func__,__LINE__);
    /* To generate panic uncomment following */
    /* panic("softlockup: hung tasks"); */
 
    while(!kthread_should_stop()) {
        printk(KERN_INFO "%s:%d\n",__func__,__LINE__);
        spin_lock(&spinlock);
        /* busy loop in critical section */
        while(1) {
            printk(KERN_INFO "%s:%d\n",__func__,__LINE__);
        }
 
        spin_unlock(&spinlock);
    }
 
    return val;
}
 
static int softlockup_init(void)
{
    printk(KERN_INFO "%s:%d\n",__func__,__LINE__);
 
    val = 1;
    spin_lock_init(&spinlock);
    task0 = kthread_run(&task,(void *)val,"softlockup_thread");
    set_cpus_allowed_ptr(task0, cpumask_of(0));  //调用该接口绑定
 
    return 0;
}
 
static void softlockup_exit(void)
{
    printk(KERN_INFO "%s:%d\n",__func__,__LINE__);
    kthread_stop(task0);
}
 
module_init(softlockup_init);
module_exit(softlockup_exit);

四、总结

在项目开发过程中,某些cpu的使用率很高,而有些使用率较低,我们可以尝试使用设置cpu的亲和度来调整不同cpu上的task

相关推荐
月殇_木言2 小时前
Linux 线程
linux
wangjialelele2 小时前
Linux中的线程
java·linux·jvm·c++
2301_800050994 小时前
DNS 服务器
linux·运维·笔记
Lin_Aries_04214 小时前
容器化简单的 Java 应用程序
java·linux·运维·开发语言·docker·容器·rpc
SELSL4 小时前
SQLite3的API调用实战例子
linux·数据库·c++·sqlite3·sqlite实战
小牛马爱写博客5 小时前
DNS 服务器与 DHCP 服务器详解及配置指南
linux·运维·服务器·dns·dhcp
维尔切5 小时前
HAProxy 负载均衡器
linux·运维·数据库·负载均衡
什么半岛铁盒5 小时前
C++项目:仿muduo库高并发服务器-------Channel模块实现
linux·服务器·数据库·c++·mysql·ubuntu
小白银子5 小时前
零基础从头教学Linux(Day 42)
linux·运维·服务器·网络·nginx
望获linux5 小时前
【Linux基础知识系列:第一百四十篇】理解SELinux与系统安全
linux·运维·服务器·数据库·chrome·macos