CPU亲和度
CPU亲和度(CPU Affinity),就是将一个进程或者线程强制绑定在CPU的某一个core上运行。
参考:https://www.cnblogs.com/zhangxuan/p/6427533.html
https://www.cnblogs.com/LubinLew/p/cpu_affinity.html
demo是将ljj_test进程强制绑定在CPU core7上运行。
代码如下:
- #define __USE_GNU //这个必须要加,不然编译不过,因为在sched.h中,用该宏控制打开和关闭cpu_set_t的定义
- #include <stdio.h>
- #include <unistd.h>
- #include <sched.h>
- #include <stdlib.h>
- int main(){
- int i, pid, ret, num;
- cpu_set_t mask;
- pid = getpid();
- num = sysconf(_SC_NPROCESSORS_CONF); //获取核数
- printf("[ljj_test] pid = %d, cpu cores = %d\n",pid, num);
- CPU_ZERO(&mask);//clear
- CPU_SET(, &mask);//cpu7
- ret = sched_setaffinity(pid, sizeof(cpu_set_t), &mask);
- if(ret < )
- {
- printf("[ljj_test]---error1\n");
- return -;
- }
- CPU_ZERO(&mask);//clear
- ret = sched_getaffinity(pid, sizeof(cpu_set_t), &mask);
- if(ret < )
- {
- printf("[ljj_test]---error2\n");
- return -;
- }
- for (i = ; i < num; i++)
- {
- if (CPU_ISSET(i, &mask))//判断线程与哪个CPU有亲和力
- printf("this thread %d is running processor : %d\n", i,i);
- }
- i = ;
- while(i--)
- {
- sleep();
- printf("[ljj_test]---cnt = %d\n", i);
- }
- return ;
- }
运行log如下:
- htc_imedugl:/ # ./system/xbin/ljj_test
- [ljj_test] pid = , cpu cores =
- this thread is running processor :
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
- [ljj_test]---cnt =
同时,我也抓取了systrace,用于check进程的运行情况。如下:
首先,一开始运行ljj_test,没有设置亲和度,那么它默认从CPU0上运行了(这个不一定每次是CPU core0,是会从进程调度的管理中动态选择core而运行new task):
而后,设置了CPU亲和度,将进程绑定到了CPU core7上,
因为使用了一个while循环,多次运行printf,但是由于使用的是sleep函数,会主动放弃时间片,所以只有一小段时间是处于running:
并且每个间隔都约1s:
CPU亲和度的更多相关文章
- nginx 网络模型,cpu亲和等优点
nginx优点1.IO多路复用epollIO多路复用:多个描述符的I/O操作都能在一个线程内并发交替地顺序完成,这里的"复用" 指的是复用同一个线程epollIO多路复用的实现方式 ...
- Redis优化之CPU充分利用
Linux Redis Server之CPU充分利用 不知道大家有没有注意到你们公司的集群配置是否是有一种配置是这样的: 多个Redis Server分布在同一个节点,只是端口不同,如果有的话,应该是 ...
- linux系统设置cpu孤立
介绍 针对cpu密集型的任务,消耗cpu较高,最好设置cpu亲和度,以提高任务执行效率,避免cpu进行上下文切换,浪费不必要的性能. 特定任务(进程/线程)需要独占一个cpu核心并且不想让其他任务(进 ...
- python之psutil模块(获取系统性能信息(CPU,内存,磁盘,网络)
一.psutil模块 1. psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网络等) ...
- Linux -- 进程或线程独占CPU
如果想让特定进程或线程独占某一或某些CPU,我们需要做三件事. 一,隔离CPU,避免其它线程run在被隔离的CPU上. 二,绑定所有的interrupts到非隔离的CPU上,避免被隔离的CPU收到in ...
- Cocos2dx中线程优先级
Cocos2dx中线程优先级问题 不论是ios还是android,遇到耗时的任务都要另起线程处理,否则程序不能及时用户的反馈.游戏中如果一圈循环不能在1/frameRate(帧率是30则1/30)秒内 ...
- psutil 模块
psutil.pids()查看单个进程p = psutil.Process(2423) p.name() #进程名p.exe() #进程的bin路径p.cwd() #进程的工作目录绝对 ...
- python之系统性能信息模块psutil
系统性能信息模块psutil 跨平台库 轻松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网络等)信息. 主要用于系统监控,分析和限制系统资源及进程的管理 实现同等命令行工具提供的功能( ...
- 15.python笔记之psutil模块
一.psutil模块 1. psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网络等) ...
随机推荐
- Adobe Reader XI 打开后“已停止工作”的解决办法
搜了好多方法按照步骤做完,基本无用,试了以下方法搞定. 具体方法是: 把域名解析到本机. 打开 C:\Windows\System32\drivers\etc\hosts 添加 127.0.0.1 a ...
- Openwrt:逆向永久修改Flash中的Mac地址
get mtd device cat /proc/mtd dev: size erasesize name mtd0: 00800000 00010000 "ALL" mtd1: ...
- Vant 顶部导航栏【van-tabs】Bug
Vant 顶部导航栏[van-tabs]Bug 如果在外面包裹div控制显示隐藏会出现导航条不准确的bug 代码 <div class="selWrap" v-show=&q ...
- vue路由元之进入路由需要用户登录权限功能
为什么需要路由元呢??? 博猪最近开发刚刚好遇到一个情况,就是有个路由页面里面包含了客户的信息,客户想进这个路由页面的话, 就可以通过请求数据获取该信息,但是如果客户没有登录的话,是不能进到该页面的, ...
- [hdu4628 Pieces]二进制子状态,DP
题意:给一个长度为16的字符串,每次从里面删掉一个回文序列,求最少需要几次才能删掉所有字符 思路:二进制表示每个字符的状态,那么从1个状态到另一个状态有两种转移方式,一是枚举所有合法的回文子序列,判断 ...
- [codeforces-543-D div1]树型DP
题意:给一棵树的边标上0或1,求以节点i为源点,其它点到i的唯一路径上的1的边数不超过1条的方案数,输出所有i的答案. 思路:令f[i]表示以节点i为源点,只考虑子树i时的方案数,ans[i]为最后答 ...
- 使用plupload实现多文件上传,自定义参数
下载地址:点击打开链接 1.在开发中可能需要用户附件上传的功能,实现批量上传功能其实就将多个上传任务放到一个集合中,分别上传. 2,使用plupload js插件可以很轻松的实现带参数的多文件上传 3 ...
- 51Nod - 1255
也是第十一届校赛的C题,不过他把1e5改成了1e7. 一开始就想到用贪心做.思路是这样的:开一个字符数组ans保存答案.然后从头到尾遍历题目给出的字符串S,如果ans数组中还没有这个字母,那么就把字母 ...
- C#中的any和all
any是判断列表里面是否有哪怕一个: all是判断列表里面是否每一项都包含:
- ubuntu18.04.4安装k8s
k8s部署 1.集群所有主机关闭swap sudo swapoff -a sudo sed -i 's/.*swap.*/#&/' /etc/fstab 如果重启后swap还是自动挂载执行sy ...