将进程绑定到指定CPU
来源:互联网 发布:数控线切割编程bbb 编辑:程序博客网 时间:2024/05/20 16:37
现在多CPU的趋势越来越大了. 有时候为了更好地操作机器, 需要将某个进程绑定到具体的CPU上去. 下面给出了一个进程绑定到具体的CPU上去的一个例子.
cpu.c
下面是在两个终端分别执行了./cpu 0 ./cpu 2 后得到的结果. 效果比较明显.
使用#define __USE_GNU是为了使用CPU_SET()等宏. 具体在/usr/include/sched.h中有如下的定义.
- #ifdef __USE_GNU
- /* Access macros for `cpu_set'. */
- #define CPU_SETSIZE __CPU_SETSIZE
- #define CPU_SET(cpu, cpusetp) __CPU_SET (cpu, cpusetp)
- #define CPU_CLR(cpu, cpusetp) __CPU_CLR (cpu, cpusetp)
- #define CPU_ISSET(cpu, cpusetp) __CPU_ISSET (cpu, cpusetp)
- #define CPU_ZERO(cpusetp) __CPU_ZERO (cpusetp)
- /* Set the CPU affinity for a task */
- extern int sched_setaffinity (__pid_t __pid, size_t __cpusetsize,
- __const cpu_set_t *__cpuset) __THROW;
- /* Get the CPU affinity for a task */
- extern int sched_getaffinity (__pid_t __pid, size_t __cpusetsize,
- cpu_set_t *__cpuset) __THROW;
- #endif
CPU Affinity (CPU亲合力):
CPU亲合力就是指在Linux系统中能够将一个或多个进程绑定到一个或多个处理器上运行.
一个进程的CPU亲合力掩码决定了该进程将在哪个或哪几个CPU上运行.在一个多处理器系统中,设置CPU亲合力的掩码可能会获得更好的性能.
一个CPU的亲合力掩码用一个cpu_set_t结构体来表示一个CPU集合,下面的几个宏分别对这个掩码集进行操作:
CPU_ZERO() 清空一个集合
CPU_SET()与CPU_CLR()分别对将一个给定的CPU号加到一个集合或者从一个集合中去掉.
CPU_ISSET()检查一个CPU号是否在这个集合中.
其实这几个的用法与select()函数那几个调用差不多.
下面两个函数就是最主要的了:
sched_setaffinity(pid_t pid, unsigned int cpusetsize, cpu_set_t *mask)
该函数设置进程为pid的这个进程,让它运行在mask所设定的CPU上.如果pid的值为0,则表示指定的是当前进程,使当前进程运行在mask所设定的那些CPU上.第二个参数cpusetsize是mask所指定的数的长度.通常设定为sizeof(cpu_set_t).如果当前pid所指定的CPU此时没有运行在mask所指定的任意一个CPU上,则该指定的进程会从其它CPU上迁移到mask的指定的一个CPU上运行.
sched_getaffinity(pid_t pid, unsigned int cpusetsize, cpu_set_t *mask)
该函数获得pid所指示的进程的CPU位掩码,并将该掩码返回到mask所指向的结构中.即获得指定pid当前可以运行在哪些CPU上.同样,如果pid的值为0.也表示的是当前进程.
这几个宏与函数的具体用法前面已经有讲解.
关于cpu_set_t的定义
在我的机器上sizeof(cpu_set_t)的大小为128,即一共有1024位.第一位代表一个CPU号.某一位为1则表示某进程可以运行在该位所代表的cpu上.
例如:
CPU_SET(1, &mask);
则mask所对应的第2位被设置为1.
此时如果printf("%d\n", mask.__bits[0]);就打印出2.表示第2位被置为1了.
具体我是参考man sched_setaffinity文档中的函数的.
然后再参考了一下IBM的 developerWorks上的一个讲解.
http://www.ibm.com/developerworks/cn/linux/l-affinity.html
- 将进程绑定到指定CPU
- 如何绑定进程到指定的CPU
- linux绑定进程到指定cpu
- linux绑定进程到指定cpu
- 将进程绑定到特定的cpu
- LINUX将制定的线程号、进程号绑定到指定CPU核上
- windows下绑定线程(进程)到指定CPU
- 多线程编程中,将线程绑定到指定CPU
- 设置cpu亲和性---即 绑定特定的进程线程到指定的cpu
- android将线程绑定在指定CPU
- windows下绑定线程(进程)到指定的CPU核心
- windows下绑定线程(进程)到指定的CPU核心
- windows下绑定线程(进程)到指定的CPU核心
- windows下绑定线程(进程)到指定的CPU核心
- 绑定某process到指定CPU
- C#线程绑定到指定cpu
- linux线程绑定到指定cpu运行
- 如何将一个进程(线程)绑定到一个固定的CPU核上?
- 软件防破解之Android JNI的应用
- AndroidStudio配置SSH连接GitHub
- reportNG定制化之失败截图,包括reportNG打包
- 【Java】请区分好length、length()和size()的区别
- express 和 ajax的集成
- 将进程绑定到指定CPU
- IPC机制
- iTextSharp.dll生成pdf 实战实例
- 应用TP3.2.3的一些小问题(一)
- [python][基础知识] 字符串操作
- POJ 2778 DNA Sequence 矩阵快速幂+AC自动机
- Java 接口知识点
- Windows OpenCV2.4.13 VS2015 编译
- 重做日志文件