成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

虛擬化環境下服務器負載均衡的參考實現

運維 服務器運維 虛擬化
本文介紹了虛擬化環境下對服務器CPU利用率進行負載均衡的簡單實現。功能通過Python腳本實現,可以在某臺服務器CPU利用率過高的時候自動將虛擬機實時遷移到其他利用率低的機器上。

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

python實現的腳本如下,這個腳本需要5個數字參數的輸入,分別為:

***CPU利用率,***CPU利用率,初始線程數量,每次調節的線程數量,每個線程睡眠的時間(毫秒)

當然,很大程度上,由于硬件環境的不同,這些參數帶有很強的經驗性。

  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 #線程運行標示,用于將來減少線程時能夠正常結束  
  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函數。  
  16. #相比之下,usleep還是相當強大的,而python的sleep單位為秒,雖然可以輸入浮點數,
    但還是相對弱了些
     
  17. def stop(self):  
  18. self.runflag = False 
  19. #讓其正常終止循環  
  20. threadList=[]  
  21. print 'Start Thread Number:' sys.argv[3'\tSleep Time(ms):' sys.argv[5]  
  22. #初始化一定數量的線程,否則從零開始,可能需要很長的時間才能達到指定范圍  
  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利用率。然后通過比較,進行自適應調整  
  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.  

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

【編輯推薦】

  1. 服務器CPU利用率100%的常見解決方法
  2. Linux下的CPU利用率計算原理詳解
  3. CentOS sensors軟件監控主板CPU數據
責任編輯:yangsai 來源: Intel_ISN
相關推薦

2009-07-22 10:25:37

2009-01-10 18:53:01

服務器ServerDNS

2010-05-05 22:40:21

apache服務器負載均衡

2011-11-22 21:26:59

pfSense配置Web服務器負載均衡

2010-11-19 12:53:53

梭子魚負載均衡

2010-05-10 14:02:53

服務器負載均衡

2010-05-05 18:44:27

服務器負載均衡

2010-05-05 18:28:16

負載均衡服務器

2013-01-28 13:38:57

虛擬化服務器網絡接入網絡虛擬化

2013-12-13 09:52:58

VDI服務器負載均衡

2012-10-16 16:43:04

虛擬化服務器虛擬化數據中心網絡

2010-04-30 09:40:41

2018-10-14 08:39:52

NginxTomcat服務器

2012-06-12 09:36:14

虛擬化網絡存儲

2010-04-22 23:07:47

服務器負載均衡

2010-04-26 17:41:29

服務器負載均衡

2012-06-19 09:45:51

服務器虛擬化

2018-03-14 11:13:35

Web服務器Nginx

2010-05-06 14:15:02

流媒體服務器負載均衡

2009-02-27 11:32:00

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美久久不卡 | 午夜视频一区 | 国产精品久久国产精品 | 日韩成人免费视频 | 国产激情视频网站 | 日韩视频区| 亚洲精品一区二区二区 | 国产成人精品久久二区二区91 | 91亚洲精品国偷拍自产在线观看 | 91精品国产欧美一区二区 | 青青草视频免费观看 | 日本亚洲欧美 | 在线国产一区二区三区 | 日日夜夜精品视频 | 久久爆操 | 三级免费网 | 亚洲国产精品一区二区第一页 | 国产精品久久久久久久久久久免费看 | 午夜久久久久 | 欧洲视频一区二区 | 日韩一区二区三区视频在线观看 | 精品一二区| 日韩精品久久久久 | 毛片区 | 欧美影院 | 午夜性视频 | 久草热线 | 青草久久免费视频 | 黑人巨大精品欧美一区二区免费 | 久久久久久久电影 | 日韩三级在线观看 | 成人妇女免费播放久久久 | 亚洲一区在线日韩在线深爱 | 日韩福利| 一区二区精品电影 | 久久久日韩精品一区二区三区 | 国产福利在线 | 亚洲男人天堂2024 | 久久在线免费 | 精品一区国产 | 91精品久久久久久久久99蜜臂 |