Linux下多核CPU指定程序运行的核

设置程序在指定CPU核心运行

一、如何查看程序运行的CPU信息

1.1 查看当前系统CPU有几个核心

查看CPU核心数量:lscpu

1.2 查看程序的PID

shell 复制代码
ps aux|grep cpu_test

1.3 查看程序可运行的CPU

shell 复制代码
taskset -c -p pid

1.4 设置程序在指定核心上运行

1.4.1 通过运行时的参数设置

shell 复制代码
taskset -c 1 ./cpu_test

1.4.2 通过代码设置

c 复制代码
#define _GNU_SOURCE
#include <stdio.h>
#include <sched.h>
int main() {
        cpu_set_t mask;
        CPU_ZERO(&mask);
        CPU_SET(1,&mask);

        if(sched_setaffinity(0,sizeof(mask),&mask)== -1)
        {
                perror("sched setaffinity");
                return -1;
        }
    while(1)
    {
        printf("Hello, World!\n");
        sleep(1);

    }
    return 0;
}

二、未设置程序在指定CPU核心运行

c 复制代码
// cpu_test.c
#include <stdio.h>
int main() {

    while(1)
    {
        printf("Hello, World!\n");
        sleep(1);

    }
    return 0;
}

查看程序的PID

查看程序可运行的核

得出该程序可以在0-3 4个核上运行。

三、设置程序在指定CPU核心运行

假设我们要使程序运行在第2个核上:

c 复制代码
#define _GNU_SOURCE
#include <stdio.h>
#include <sched.h>
int main() {
        cpu_set_t mask;
        CPU_ZERO(&mask);
        CPU_SET(1,&mask);

        if(sched_setaffinity(0,sizeof(mask),&mask)== -1)
        {
                perror("sched setaffinity");
                return -1;
        }
    while(1)
    {
        printf("Hello, World!\n");
        sleep(1);

    }
    return 0;
}

查看程序的PID

查看程序可运行的CPU核

得出设置成功,已将程序绑定在CPU的第2个核上。

相关推荐
q***13341 小时前
Linux(CentOS)安装 Nginx
linux·nginx·centos
摘星编程2 小时前
openGauss 快速上手:CentOS 环境下单机部署完整指南
linux·运维·centos
哈里谢顿6 小时前
使用kvm创建一台虚拟机
linux
大喵桑丶7 小时前
中间件快速部署(Nginx,Keepalived)
运维·nginx·中间件
hanyi_qwe8 小时前
文本三剑客--awk
linux·运维·服务器
liu****8 小时前
27.epoll(三)
服务器·开发语言·网络·tcp/ip·udp
Caven778 小时前
【Linux 技巧】如何在登录时自动激活 Conda Base 环境
linux·运维·conda
凌寒118 小时前
Linux(Debian)安装、卸载 MySQL
linux·运维·mysql·debian
云飞云共享云桌面8 小时前
如何降低非标自动化工厂的研发软件采购成本
运维·服务器·网络·数据库·性能优化·自动化
七七墨染8 小时前
DotMemory系列:5. 如何实现自动化抓取和应用自托管
运维·c#·自动化