Linux上将进程、线程与CPU核绑定

      CPU亲和性(CPU Affinity)是某一进程(或线程)绑定到特定的CPU核(或CPU集合),从而使得该进程(或线程)只能运行在绑定的CPU核(或CPU集合)上。进程(或线程)本质上并不与CPU核绑定。每次进程(或线程)被调度执行时,它都可以由其关联列表中的任何CPU核执行。如果未显式设置关联列表,则进程(或线程)可以在任何CPU核上运行。

      一.查看CPU信息
      1.通过命令,执行:

cat /proc/cpuinfo

      (1).processor:指明每个物理CPU中逻辑处理器信息,序号从0开始;
      (2).cpu cores: 指明每个物理CPU中总核数;
      2.查看物理CPU个数,执行:

cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc -l

      3.查看每个物理CPU中core的个数(即核数),执行:

cat /proc/cpuinfo | grep "cpu cores" | uniq

      4.查看逻辑CPU的个数,执行:

cat /proc/cpuinfo | grep "processor" | wc -l

      5.通过代码:sysconf函数或get_nprocs函数

void get_cpu_cores()
{// _SC_NPROCESSORS_CONF:系统配置的CPU核心数量// _SC_NPROCESSORS_ONLN:当前系统实际可用的CPU核心数量,可能会因为系统的运行状态而变化// 两个函数返回的值可能并不完全相同std::cout << "cpu cores(_SC_NPROCESSORS_CONF): " << sysconf(_SC_NPROCESSORS_CONF) << "\n";std::cout << "cpu cores(_SC_NPROCESSORS_ONLN): " << sysconf(_SC_NPROCESSORS_ONLN) << "\n";// get_nprocs_conf:系统配置的CPU核心数量; get_nprocs:当前系统中可用的CPU核心数量,此值可能小于get_nprocs_conf返回的值std::cout << "cpu cores(get_nprocs_conf): " << get_nprocs_conf() << "\n";std::cout << "cpu cores(get_nprocs): " << get_nprocs() << "\n"; 
}

      二.将进程绑定到指定的CPU核上
      1.通过taskset:(-p:pid; -c:cpu list)
      (1).查看执行程序(进程)运行在哪个CPU核上:taskset -p 进程ID(PID, 操作系统分配给每个进程的唯一标识符)
      如查看gnome-shell运行在哪个CPU核上:通过top命令查看gnome-shell的PID为1246,输入:taskset -pc 1246 ,执行结果如下图所示:

      (2).启动时指定:CPU标号从0开始,绑定多个CPU核,之间用逗号分隔
    taskset -c CPU_标号 可执行程序
      (3).启动后绑定:CPU标号从0开始,绑定多个CPU核,之间用逗号分隔
    taskset -pc CPU_标号 PID
      2.通过代码:sched_setaffinity和sched_setaffinity函数
      (1).sched_setaffinity(pid_t pid, size_t cpusetsize, const cpu_set_t *mask): 将ID为pid的线程的CPU亲和性掩码(CPU affinity mask)设置为mask指定的值。如果pid为0,则使用调用线程。参数cpusetsize是 mask指向的数据的长度(以字节为单位)。通常该参数被指定为sizeof(cpu_set_t)。
      (2).sched_getaffinity(pid_t pid, size_t cpusetsize, cpu_set_t *mask): 将ID为pid的线程的亲和性掩码写入mask指向的cpu_set_t结构中。cpusetsize参数指定掩码的大小(以字节为单位)。如果pid为零,则返回调用线程的掩码。

void set_processor_to_cpu_core()
{{ // sched_getaffinitycpu_set_t mask;CPU_ZERO(&mask);if (sched_getaffinity(0, sizeof(mask), &mask) != 0)std::cerr << "Error: fail to sched_getaffinity\n";for (auto i = 0; i < sysconf(_SC_NPROCESSORS_ONLN); ++i) {if (CPU_ISSET(i, &mask))std::cout << "CPU " << i << " is set\n";}
}{ // sched_setaffinitycpu_set_t mask;CPU_ZERO(&mask);// 可以多次调用CPU_SET,以指定将多个CPU核添加到mask中CPU_SET(0, &mask); // set affinity for core 0, set the bit that represents core 0if (sched_setaffinity(0, sizeof(mask), &mask) != 0)std::cerr << "Error: fail to sched_setaffinity\n";
}}

      三.将线程绑定到指定的CPU核上
      1.通过代码:pthread_setaffinity_np函数和pthread_getaffinity_np
      (1).pthread_setaffinity_np(pthread_t thread, size_t cpusetsize, const cpu_set_t *cpuset): 将线程thread的CPU亲和性掩码(CPU affinity mask)设置为cpuset指向的CPU集。如果调用成功,并且该线程当前未在cpuset中的某个CPU上运行,则它将迁移到这些CPU中的一个。
      (2).pthread_getaffinity_np(pthread_t thread, size_t cpusetsize, cpu_set_t *cpuset): 获取cpuset指向的缓冲区中线程thread的CPU亲和性掩码。

void get_thread_id(int n)
{std::cout << "thread id: " << std::this_thread::get_id() << ", on cpu: " << sched_getcpu() << "\n";std::this_thread::sleep_for(std::chrono::seconds(n));
}void set_thread_to_cpu_core()
{// 最大的硬件并发线程数std::cout << "Support concurrent threads: " << std::thread::hardware_concurrency() << "\n";std::thread th1(get_thread_id, 5), th2(get_thread_id, 5);
{ // pthread_getaffinity_npcpu_set_t cpuset;CPU_ZERO(&cpuset);if (pthread_getaffinity_np(th1.native_handle(), sizeof(cpuset), &cpuset) != 0)std::cerr << "Error: fail to pthread_getaffinity_np\n";// for (auto i = 0; i < sysconf(_SC_NPROCESSORS_ONLN); ++i) {//     if (CPU_ISSET(i, &cpuset))//         std::cout << "CPU " << i << " is set\n";// }
}{ // pthread_setaffinity_npcpu_set_t cpuset;CPU_ZERO(&cpuset);// 可以多次调用CPU_SET,以指定将多个CPU核添加到cpuset中CPU_SET(0, &cpuset); // set affinity for core 0, set the bit that represents core 0if (pthread_setaffinity_np(th2.native_handle(), sizeof(cpuset), &cpuset) != 0)std::cerr << "Error: fail to pthread_setaffinity_np\n";}th1.join();th2.join();
}

      以上测试代码执行结果如下图所示:虚拟机

      GitHub:https://github.com/fengbingchun/Linux_Code_Test

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/125855.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java常见API---split()

package daysreplace;public class SplitTest {public static void main(String[] args) {String str"武汉市|孝感市|长沙市|北京市|上海市";String[] array str.split("\\|");System.out.println(array[0]);System.out.println(array[1]);System.out.pri…

Unity2D创建帧动画片段

文章目录 概述为角色创建动画Animator组件创建动画片段状态转移 其他文章 概述 动画是游戏中一种使对象表现出运动或变换的方式。当涉及到动画时&#xff0c;我们通常就会用到Animator组件。它允许我们在Unity编辑器中创建、管理和控制这些动画&#xff0c;并将其应用于游戏对…

推荐系统实践 笔记

诸神缄默不语-个人CSDN博文目录 这是我2020年写的笔记&#xff0c;我从印象笔记搬过来公开。 如果那年还在读本科的同学也许有印象&#xff0c;那年美赛出了道根据电商评论给商户提建议的题。其实这件事跟推荐系统关系不大&#xff0c;但我们当时病急乱投医&#xff0c;我打开…

【开发篇】十六、SpringBoot整合JavaMail实现发邮件

文章目录 0、相关协议1、SpringBoot整合JavaMail2、发送简单邮件3、发送复杂邮件 0、相关协议 SMTP&#xff08;Simple Mail Transfer Protocol&#xff09;&#xff1a;简单邮件传输协议&#xff0c;用于发送电子邮件的传输协议POP3&#xff08;Post Office Protocol - Versi…

RabbitMQ集群搭建详细介绍以及解决搭建过程中的各种问题——实操型

RabbitMQ集群搭建详细介绍以及解决搭建过程中的各种问题——实操型 1. 准备工作1.1 安装RabbitMQ1.2 简单部署搭建设计1.3 参考官网 2. RabbitMQ 形成集群的方法3. 搭建RabbitMQ集群3.1 部署架构3.2 rabbitmq集群基础知识3.2.1 关于节点名称&#xff08;标识符&#xff09;3.2.…

鱼眼相机去畸变(图像拉直/展开/矫正)算法及实战总结

本文介绍两种方法 1、经纬度矫正法 2、棋盘格矫正法 一、经纬度矫正法 1、算法说明 经纬度矫正法&#xff0c; 可以把鱼眼图想象成半个地球&#xff0c; 然后将地球展开成地图&#xff0c;经纬度矫正法主要是利用几何原理&#xff0c; 对图像进行展开矫正。 经过P点的入射光线…

掌握交易时机!

“您是否知道您选择购买和出售加密货币的时间会产生很大的影响&#xff1f;当然&#xff0c;大多数交易者都知道高价卖出和低价买入的基本知识。然而&#xff0c;在选择交易加密货币的最佳时机时&#xff0c;还需要考虑许多其他小细节。加密货币市场分析表明&#xff0c;一天中…

中秋时节赏明月,五子棋戏月饼趣 — Flutter中秋限定版五子棋

前言 当中秋时节来临&#xff0c;我们都期待着与亲人朋友共度这个美好的节日。这个时候&#xff0c;除了传统的赏月和品尝美味的月饼&#xff0c;我还有一个特别的建议——尝试一款有趣的Flutter五子棋游戏&#xff01;这款五子棋游戏以中秋为主题&#xff0c;游戏的棋子也可爱…

阿里云服务器IP地址查询方法(公网IP和私网IP)

阿里云服务器IP地址在哪查看&#xff1f;在云服务器ECS管理控制台即可查看&#xff0c;阿里云服务器IP地址包括公网IP和私有IP地址&#xff0c;阿里云百科分享阿里云服务器IP地址查询方法&#xff1a; 目录 阿里云服务器IP地址查询 阿里云服务器IP地址查询 1、登录到阿里云服…

数据结构:二叉树(超详解析)

目录​​​​​​​ 1.树概念及结构 1.1树的概念 1.2树的相关概念 1.3树的表示 1.3.1孩子兄弟表示法&#xff1a; 1.3.2双亲表示法&#xff1a;只存储双亲的下标或指针 两节点不在同一树上&#xff1a; 2.二叉树概念及结构 2.1.概念 2.2.特殊的二叉树&#xff1a; 2…

ESP32/ESP8266在线刷写Sonoff Tasmota固件以及配置简要

ESP32/ESP8266在线刷写Sonoff Tasmota固件以及配置简要 &#x1f4cd;原项目Github地址&#xff1a;https://github.com/arendst/Tasmota/tree/v13.1.0&#x1f4d1;官方文档介绍&#xff1a;https://tasmota.github.io/docs/&#x1f6a9;(✨推荐方式✨)在线固件刷写地址&…

【数据结构】排序算法(二)—>冒泡排序、快速排序、归并排序、计数排序

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 目录 前言 1.冒泡排序 2.快速排序 2.1Hoare版 2.2占…