linux下简单的自适应CPU利用率的控制(Python实现)
作者 佚名技术
来源 Linux系统
浏览
发布时间 2012-05-17
最近在做的是虚拟化相关的一个demo,牵涉到虚拟化环境下的服务器负载均衡.我们用到一个简单的case,就是在负载出现“不平衡”的时候,进行
live
migration.![]() ![]() 最低CPU利用率,最高CPU利用率,初始线程数量,每次调节的线程数量,每个线程睡眠的时间(毫秒) 当然,很大程度上, ![]() import time import os import string import sys class ControlThread(threading.Thread): def __init__(self): threading.Thread.__init__(self) self.runflag = True #线程运行标示,用于将来减少线程时能够正常结束 def run(self): while self.runflag: os.popen(''usleep '' sys.argv[5]) #time.sleep(string.atof(sys.argv[5])) #这里使用的是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]):#增加线程 for i in range(0,string.atoi(sys.argv[4])): thread = ControlThread() thread.start() threadList.append(thread) print " " if output > string.atoi(sys.argv[2]):#减少线程 for i in range(0,string.atoi(sys.argv[4])): thread = threadList.pop() thread.stop() print "-----" 总的来说,这个脚本比较简单, ![]() ![]() |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于linux下简单的自适应CPU利用率的控制(Python实现)的所有评论