虚拟化环境下服务器负载均衡的参考实现

运维 服务器运维 虚拟化
本文介绍了虚拟化环境下对服务器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

服务器负载均衡

2013-12-13 09:52:58

VDI服务器负载均衡

2013-01-28 13:38:57

虚拟化服务器网络接入网络虚拟化

2010-05-05 18:44:27

服务器负载均衡

2010-05-05 18:28:16

负载均衡服务器

2012-10-16 16:43:04

虚拟化服务器虚拟化数据中心网络

2018-10-14 08:39:52

NginxTomcat服务器

2012-06-12 09:36:14

虚拟化网络存储

2010-04-30 09:40:41

2010-04-26 17:41:29

服务器负载均衡

2010-04-22 23:07:47

服务器负载均衡

2018-03-14 11:13:35

Web服务器Nginx

2012-06-19 09:45:51

服务器虚拟化

2010-05-06 14:15:02

流媒体服务器负载均衡

2009-02-27 11:32:00

点赞
收藏

51CTO技术栈公众号