本文实例讲述了python和bash统计CPU利用率的方法。分享给大家供大家参考。具体如下:
开始的时候写了一个 bash 的实现;
因为最近也在学习 python ,所以就尝试着用 python 再实现一回;
支援 python2 环境;
请各位给予下建议,有什么改良的地方可以提一下,不甚感激;
Python代码如下:
#!/usr/bin/python # -*- coding:utf8 -*- __author__ = 'chenwx' def cpu_rate(): import time def cpu_r(): f = open("/proc/stat","r") for f_line in f: break f.close() f_line = f_line.split(" ") f_line_a=[] for i in f_line: if i.isdigit(): i=int(i) f_line_a.append(i) total = sum(f_line_a) idle = f_line_a[3] return total,idle total_a,idle_a=cpu_r() time.sleep(2) total_b,idle_b=cpu_r() sys_idle = idle_b - idle_a sys_total = total_b - total_a sys_us = sys_total - sys_idle cpu_a = (float(sys_us)/sys_total)*100 return cpu_a # print cpu_rate()
bash的实现方式:
#!/bin/bash # 感觉计算数组这里应该还有办法简化的吧; # 我一时没想到,请大家提一下建议,多谢; cpu_a=(`grep 'cpu ' /proc/stat`) total_a=$((${cpu_a[1]}+${cpu_a[2]}+${cpu_a[3]}+${cpu_a[4]}+${cpu_a[5]}+${cpu_a[6]}+${cpu_a[7]}+${cpu_a[8]}+${cpu_a[9]})) idle_a=${cpu_a[4]} sleep 5 cpu_b=(`grep 'cpu ' /proc/stat`) total_b=$((${cpu_b[1]}+${cpu_b[2]}+${cpu_b[3]}+${cpu_b[4]}+${cpu_b[5]}+${cpu_b[6]}+${cpu_b[7]}+${cpu_b[8]}+${cpu_b[9]})) idle_b=${cpu_b[4]} sys_idle=$(($idle_b-$idle_a)) sys_total=$(($total_b-$total_a)) sys_us=$(($sys_total-$sys_idle)) echo "scale=2;$sys_us/$sys_total*100" | bc
遍历数组的方法:
# 找到了解决数组计算的办法了,不过感觉for循环计算的方式还是有些繁琐; # 不知道有没有那种对数组内所有值一并计算的方法; cpu_rate_a () { cpu_a=(`grep 'cpu ' /proc/stat`) for i in ${cpu_a[@]:1} do total_a=$(($total_a+$i)) done idle_a=${cpu_a[4]} sleep 5 cpu_b=(`grep 'cpu ' /proc/stat`) for i in ${cpu_b[@]:1} do total_b=$(($total_b+$i)) done idle_b=${cpu_b[4]} sys_idle=$(($idle_b-$idle_a)) sys_total=$(($total_b-$total_a)) sys_us=$(($sys_total-$sys_idle)) local_cpu_rate=$(echo "scale=2;$sys_us/$sys_total*100" | bc) }
希望本文所述对大家的Python程序设计有所帮助。
谁能解释一下这两种方法的真正区别 vm。GetTotalizationofCPU(CloudSim.clock()); 和 cloudlet.get利用OfCpu(CloudSim.clock()); 提前感谢
问题内容: 在Linux中是否有命令或任何其他方式来获取当前或平均 CPU使用率 (对于多处理器环境)? 我在小型系统中使用嵌入式Linux。基本上,我需要确定CPU利用率,以便在CPU利用率很高的情况下,可以将新进程转移到系统中的另一个控制器,而不是在可能忙于执行更重要进程的主处理器上执行。 这个问题不仅仅在于对进程进行优先级排序,另一个控制器可以充分处理新进程,只是当主处理器不忙时,我希望它来
我正在使用mod安全规则https://github.com/SpiderLabs/owasp-modsecurity-crs清理用户输入数据。在将用户输入与mod security rule正则表达式匹配时,我面临着cpu激增和延迟。总的来说,它包含500个正则表达式来检查不同类型的攻击(xss、badrobots、generic和sql)。对于每个请求,我检查所有参数并对照所有这500个正则表
问题内容: 关于如何使用/ proc / stat中的统计信息获取CPU利用率的文章和参考文献很多。但是,它们中的大多数仅使用7个以上的CPU统计信息中的四个(用户,nice,系统和空闲),而忽略了Linux2.6中存在的剩余jiffie CPU计数(iowait,irq,softirq)。 我的问题是:iowait / irq / softirq编号是否也计入前四个编号之一(用户/ nice /
我正在制作一个方法,该方法应该计算一定时期内某个金额的利率(这些值已经在参数中定义)。这是我到目前为止拥有的代码: 我正在制作嵌套的for循环,正如您在那里看到的那样,那里缺少代码。这里我遇到了一些麻烦。第一个for循环贯穿年份,另一个应该计算总量。为了清楚变量“int年份”中定义的年份,假设它是7,那么程序应该计算每年数量的增长,因此: 主要方法如下所示: 我很感激我能得到的任何帮助!
本文向大家介绍Linux下使用python调用top命令获得CPU利用率,包括了Linux下使用python调用top命令获得CPU利用率的使用技巧和注意事项,需要的朋友参考一下 本文定位:想通过python调用top命令获取cpu使用率但暂时没有思路的情况。 如果单纯为了获得cpu的利用率,通过top命令重定向可以轻松实现,命令如下: 或 这个就不解释了,不懂的朋友查询下top的帮助文档。这里要