成人在线你懂的-成人在线免费小视频-成人在线免费网站-成人在线免费视频观看-日韩精品国产一区二区-日韩精品国产一区

掃一掃
關(guān)注微信公眾號

虛擬化環(huán)境下服務(wù)器負(fù)載均衡的參考
2010-03-17   網(wǎng)絡(luò)

筆者最近在做的是虛擬化相關(guān)的一個demo,牽涉到虛擬化環(huán)境下的服務(wù)器負(fù)載均衡。我們用到一個簡單的case,就是在負(fù)載出現(xiàn)“不平衡”的時候,進行 live migration。由于只是demo需要,我們的負(fù)載暫時只考慮到cpu的利用率。而實際準(zhǔn)備中,由于沒有客戶端的壓力,很難做到CPU利用率的精確控制。這里寫了個簡單的腳本程序,通過自適應(yīng)的調(diào)節(jié),來達到將服務(wù)器CPU利用率控制在一定的范圍內(nèi),從而為確保在某臺服務(wù)器CPU過高的時候,會自動將虛擬機live migration到其他CPU利用率低的機器上的測試做了準(zhǔn)備。

python實現(xiàn)的腳本如下,這個腳本需要5個數(shù)字參數(shù)的輸入,分別為:

最低CPU利用率,最高CPU利用率,初始線程數(shù)量,每次調(diào)節(jié)的線程數(shù)量,每個線程睡眠的時間(毫秒)

當(dāng)然,很大程度上,由于硬件環(huán)境的不同,這些參數(shù)帶有很強的經(jīng)驗性。

  1. #!/usr/bin/python  
  2. import threading  
  3. import time  
  4. import os  
  5. import string  
  6. import sys  
  7. class ControlThread(threading.Thread):  
  8. def __init__(self):  
  9. threading.Thread.__init__(self)  
  10. self.runflag = True #線程運行標(biāo)示,用于將來減少線程時能夠正常結(jié)束  
  11. def run(self):  
  12. while self.runflag:  
  13. os.popen('usleep ' sys.argv[5])  
  14. #time.sleep(string.atof(sys.argv[5]))  
  15. #這里使用的是linux下shell里面的usleep,而不是python自帶的sleep函數(shù)。  
  16. #相比之下,usleep還是相當(dāng)強大的,而python的sleep單位為秒,雖然可以輸入浮點數(shù),
    但還是相對弱了些
     
  17. def stop(self):  
  18. self.runflag = False 
  19. #讓其正常終止循環(huán)  
  20. threadList=[]  
  21. print 'Start Thread Number:' sys.argv[3'\tSleep Time(ms):' sys.argv[5]  
  22. #初始化一定數(shù)量的線程,否則從零開始,可能需要很長的時間才能達到指定范圍  
  23. for i in range(0,string.atoi(sys.argv[3])):  
  24. thread = ControlThread()  
  25. threadList.append(thread)  
  26. thread.start()  
  27. #這里使用sar來抓取cpu利用率,這里指的是總的cpu利用率。然后通過比較,進行自適應(yīng)調(diào)整  
  28. while True:  
  29. output = 100 - string.atof(os.popen('sar 1 1 | grep ^Average | awk \'
    {print $8}\''
    ).read())  
  30. print 'CPU Usage:' str(output) '\tCurrent Thread Number:' str(len(threadList))  
  31. if output < string.atoi(sys.argv[1]):#增加線程  
  32. for i in range(0,string.atoi(sys.argv[4])):  
  33. thread = ControlThread()  
  34. thread.start()  
  35. threadList.append(thread)  
  36. print " " 
  37. if output > string.atoi(sys.argv[2]):#減少線程  
  38. for i in range(0,string.atoi(sys.argv[4])):   
  39. thread = threadList.pop()  
  40. thread.stop()  
  41. print "-----" 
  42.  

總的來說,這個腳本比較簡單,而且在不同的機器上,需要操作人員的經(jīng)驗來初始化才能達到最佳效果。但這畢竟是我第一個python程序,而且也達到了預(yù)期的目的。以上只是能運行的核心代碼,至于usage,錯誤處理,退出程序等,就沒有給出來了

熱詞搜索:

上一篇:無線標(biāo)準(zhǔn)WAPI與WIFI的“曖昧關(guān)系”
下一篇:企業(yè)量身定制ERP系統(tǒng)的五大注意事項

分享到: 收藏
主站蜘蛛池模板: 美女网站视频免费| 大学生国防论文2000字| 蓝家宝电影| 天津电视台节目表| 尚大庆| 陈宝莲徐锦江夜半2普通话| 变形金刚5免费完整版在线观看| 我亲爱的简谱| 毕业论文3000字范文| 开创盛世电视剧全集免费观看| 2014年9月日历表查询| 西部往事 电影| 色在线亚洲| 年轻的丝袜老师2| 降魔的| 黄婉| 精神空虚贪图享乐具体表现及整改措施| 抗日名将卫立煌 电影| 亚洲电影在线观看| 贾樟柯对毕赣的评价| 奇门遁甲电影免费观看完整版| 谈判专家 电影| 林智妍三级全部电影| 桐谷| 749局演员表| 女同视频网站| 粤韵风华| 墓王之王动漫完整版在线观看| 电影《七天》| 六年级下册语文书50页内容| outlander| 第一介绍人与第二介绍人意见| 石田亚由美| 宇宙巨人希曼| 四年级第一二单元测试卷答案 | 凤凰电视台| 教育向美而生读书心得体会| 孕妇入院待产包清单| 四三二一| av线网| 抖音手机网页版入口|