进程cpu资源分配就是指进程的优先权(priority)。优先权高的进程有优先执行权利。配置进程优先权对多任务环境的Linux很有用,可以改善系统性能。还可以把进程运行到指定的CPU上,这样一来,把不重要的进程安排到某个CPU,可以大大改善系统整体性能。

一、先看系统进程:
PR 就是 Priority 的简写,而 NI 是nice 的简写。这两个值决定了PR的值,PR越小,进程优先权就越高,就越“优先执行”。换算公式为:PR(new) = PR(old) + NI

二、修改进程优先级的命令主要有两个:nice,renice
1、一开始执行程序就指定nice值:nice
# nice -n -5 /usr/local/mysql/bin/mysqld_safe &

Linux nice 命令详解
功能说明:设置优先权。
语  法:nice [-n
<优先等级>][--help][--version][执行指令]
补充说明:nice指令可以改变程序执行的优先权等级。

参  数:-n<优先等级>或-<优先等级>或–adjustment=<优先等级>
设置欲执行的指令的优先权等级。等级的范围从-20-19,其中-20最高,19最低,只有系统管理者可以设置负数的等级。
–help  在线帮助。

–version  显示版本信息。

—————————————————————————

2、调整已存在进程的nice:renice;PID为5200的进程nice设为-5

# renice -5 -p 5200

Linux renice 命令详解
功能说明:调整优先权。
语  法:renice [优先等级][-g
<程序群组名称>...][-p <程序识别码>...][-u <用户名称>...]

补充说明:renice指令可重新调整程序执行的优先权等级。预设是以程序识别码指定程序调整其优先权,您亦可以指定程序群组或用户名称调整优先权等级,并修改所有隶属于该程序群组或用户的程序的优先权。等级范围从-20–19,只有系统管理者可以改变其他用户程序的优先权,也仅有系统管理者可以设置负数等级。

参  数:
-g <程序群组名称>  使用程序群组名称,修改所有隶属于该程序群组的程序的优先权。
-p
<程序识别码>  改变该程序的优先权等级,此参数为预设值。
-u <用户名称>
指定用户名称,修改所有隶属于该用户的程序的优先权。


常常感觉系统资源不够用,一台机子上跑了不下3个比较重要的服务,但是每天我们还要在上面进行个备份压缩等处理,网络长时间传输,这在就很影响本就不够用的系统资源;

这个时候我们就可以把一些不太重要的比如copy/备份/同步等工作限定在一颗cpu上,或者是多核的cpu的一颗核心上进行处理,虽然这不一定是最有效的方法,但可以最大程度上利用了有效资源,降低那些不太重要的进程占用cpu资源;

查看系统下cpu信息:

#cat /proc/cpuinfo
taskset就可以帮我们完成这项工作,而且操作非常简单;

该工具系统默认安装,rpm包名util-linux

#taskset–help
 taskset (util-linux 2.13-pre7)
 usage: taskset [options]
 [mask |cpu-list] [pid | cmd [args...]]
 set or get the affinity of a
 process
 -p, –pid operate on existing given pid
 -c, –cpu-list display and
 specify cpus in list format
 -h, –help display this help
 -v, –version
 output version information

举例:
1、开启一个只用0标记的cpu核心的新进程(job.sh是你的工作脚本)

#taskset -c 0 sh job.sh
2、查找现有的进程号,调整该进程cpu核心使用情况(23328举例用的进程号)

#taskset -pc 0 23328
pid 23328′s current affinity list: 0-3
#0-3表示使用所有4核进行处理
pid 23328′s new affinity list: 0
#调整后改为仅适用0标记单核处理
3、可在top中进行负载check

最后你可以在你的工作脚本中加入该指令来合理利用现有的cpu资源;