在分析top命令代码实现前,先啰嗦几句。
最近的一个linux项目要获取cpu和内存使用率。由于linux并未提供相关的api,因此,只能通过其他手段来获取;
最开始使用的方式可简单描述如下:
1.构造一个命令字符串,该字符串的功能是通过top命令获取cpu的空闲率;
2.使用popen执行该命令;
3.使用getline等io函数从管道中读取cpu的空闲率;
4.将字符串的空闲率转换成整形值,cpu usage = 100 - idle;
至此,通过上述简单粗暴的办法完成了cpu的使用率计算。
在开始时,这个程序跑在openSuse系统上,并未发现什么问题,直到最近,把该程序放到red hat上跑时,cpu使用率计算异常,为100%。
把相关代码从项目中抠出来,增加日志打印,发现问题出在第3步,从管道读取cpu的空闲率。不同的系统上,top命令输出的数据格式存在细微差异。而上述获取cpu空闲率的方法刚好依赖于数据输出格式,所以才会出现换一种操作系统,cpu使用率计算错误问题。
为了解决上述问题,查看了ubuntu的top命令实现源码,其cpu使用率的计算方式如下:
1.打开“/proc/stat”文件。
2.读取该文件的首行,该行记录了从系统启动以来,cpu的使用信息:
cpu 1660 6942 2790 1518455 952 720 0 0 0 0
计算中我们使用到的有:
user:1660 用户态的运行时间
nice:6942 nice值为负的进程所占用的