当前位置: > CentOS > CentOS入门 >

Centos下统计多个CPU利用率

时间:2014-08-09 18:00来源:linux.it.net.cn 作者:it

一.问题的来源

MySQL在Linux下是多线程的,而且只能将多个线程分布到一个CPU上。所以,企业中,使用小型服务器,或者PC SERVER,多个CPU利用率并不高。

基本上有1~2个在使用。本文主要为了统计CPU的利用率。希望引起大家注意。

二.程序实现

1.输入 top  -bn1  (b控制输出格式为文本格式,非交互格式)

[mysql@longxibendi.host]$  top -bn1

 

2.输入top ,进入交互模式,为下一步设置输出格式做准备

[mysql@longxibendi.host]$  top 

然后输入   1

就可以看到多个CPU利用率了

top - 21:40:51 up 25 days,  9:32,  1 user,  load average: 0.15, 0.30, 0.33
Tasks: 101 total,   1 running,  96 sleeping,   0 stopped,   4 zombie
Cpu0  :  0.8% us,  0.3% sy,  0.0% ni, 98.4% id,  0.3% wa,  0.0% hi,  0.0% si
Cpu1  :  1.1% us,  0.2% sy,  0.0% ni, 98.6% id,  0.1% wa,  0.0% hi,  0.0% si
Cpu2  :  0.5% us,  0.1% sy,  0.0% ni, 99.4% id,  0.0% wa,  0.0% hi,  0.0% si
Cpu3  :  0.4% us,  0.1% sy,  0.0% ni, 99.5% id,  0.0% wa,  0.0% hi,  0.0% si
Cpu4  :  0.3% us,  0.1% sy,  0.0% ni, 99.5% id,  0.0% wa,  0.0% hi,  0.0% si
Cpu5  :  0.3% us,  0.1% sy,  0.0% ni, 99.6% id,  0.0% wa,  0.0% hi,  0.0% si
Cpu6  :  0.3% us,  0.1% sy,  0.0% ni, 99.6% id,  0.0% wa,  0.0% hi,  0.0% si
Cpu7  :  0.2% us,  0.1% sy,  0.0% ni, 99.7% id,  0.0% wa,  0.0% hi,  0.0% si

 

3.保存当前输出格式的参数(配置输出)

在2的基础上按W ,然后按ctri+c

保存退出

按q

(这样就会在/home/mysql 下有.toprc文件)

 

4.编写 shell 程序cpu.sh

#!/bin/bash

while  true

do 

     top -bcisSn1 >>cpu.log

    sleep 10

done

 

5.部署 cpu.sh 程序

   sh  cpu.sh &

 

三.分析日志

cat  cpu.log| grep cpu  等操作,就可以分析过去时间,各个cpu的利用率了。

这里省略.....,依个人爱好,输出,甚至可以把输出用cacti绘图出来。

 

四.删除配置文件

如果不想使用上述的top 输出格式,可以删除配置文件

rm /home/mysql/.toprc  

(责任编辑:IT)
------分隔线----------------------------
栏目列表
推荐内容