python实现的脚本如下,这个脚本需要5个数字参数的输入,分别为:
最低CPU利用率,最高CPU利用率,初始线程数量,每次调节的线程数量,每个线程睡眠的时间(毫秒)
当然,很大程度上,由于硬件环境的不同,这些参数带有很强的经验性。
#!/usr/bin/python
import threading
def run(self): |
#这里使用的是linux下shell里面的usleep,而不是python自带的sleep函数。
#相比之下,usleep还是相当强大的,而python的sleep单位为秒,虽然可以输入浮点数,但还是相对弱了些
def stop(self): self.runflag = False #让其正常终止循环 threadList=[] print 'Start Thread Number:' + sys.argv[3] + '\tSleep Time(ms):'+ sys.argv[5] |
#初始化一定数量的线程,否则从零开始,可能需要很长的时间才能达到指定范围
for i in range(0,string.atoi(sys.argv[3])): thread = ControlThread() threadList.append(thread) thread.start() |
#这里使用sar来抓取cpu利用率,这里指的是总的cpu利用率。然后通过比较,进行自适应调整
while True: output = 100 - string.atof(os.popen('sar 1 1 | grep ^Average | awk \'{print $8}\'').read()) print 'CPU Usage:' + str(output) + '\tCurrent Thread Number:' + str(len(threadList)) if output < string.atoi(sys.argv[1]):#增加线程 |
总的来说,这个脚本比较简单,而且在不同的机器上,需要操作人员的经验来初始化才能达到最佳效果。但这毕竟是我第一个python程序,而且也达到了预期的目的。以上只是能运行的核心代码,至于usage,错误处理,退出程序等,就没有给出来了:)
(责任编辑:A6)