标签:
在很多的商业场景中,用户的访问,峰值时间都是很难预测的,尤其是做一些市场推广活动和促销的时候,到底部署什么规模的web集群合适,这一直是个问题,部署过量会造成高成本和资源不必要的浪费,部署过少,如果到达峰值,来不及部署,容易造成用户无法访问,用户体验差,交易损失等等,当然更不用提运维人员时刻神经紧绷的实时监测压力情况,以便及时采取措施……
在云计算技术日新月异的今天,这个场景是非常不和谐的:)VMSS作为Azure新的计算方式,提供了按照压力负载自动扩展收缩,并且同时支持Windows和Linux,在提供了IAAS级别的控制灵活性的同时,也提供了PAAS级别的自动扩展,对于无状态的web服务器应用等场景非常适合,本文介绍如何通过ARM模板和VMSS创建一个自动负载均衡的,按照你的CPU负载自动扩展的web服务器集群:
在本模板中,将会创建如下测试环境:
https://github.com/Azure/azure-quickstart-templates/tree/master/201-vmss-lapstack-autoscale
https://github.com/kingliantop/azurelabs/tree/master/AzureChinaARMTemplate/vmss-lapstack-autoscale
?
模板定义:
?
?
?
?
在本次测试中,提供了两个PHP web文件,一个是index.php,用来显示当前的web应用跑在哪个服务器上,另外一个是do_work.php用来给web服务器产生压力,触发自动扩展。
?
?
?
?
#用你的Azure账号登陆
Login-AzureRmAccount -EnvironmentName AzureChinaCloud
#执行部署脚本
9 .点击负载均衡器,获得公网的IP地址或者DNS,在浏览器中打开,可以看到当前连接的是001 web服务器,该页面是一个demo页面,用于给虚拟机产生压力;新打开一个浏览器,连接负载均衡器,可以看到请求被分发到了002 web服务器:
10 . 在当前的测试页面上,输入500秒,作为压力测试时长,点击"DO work",那么PHP程序就会产生压力,占满CPU:
11. 大约等待5,6分钟以后,连续5分钟的CPU负载超过60%,我们打开新portal的虚拟机扩展页面的实例页面,可以看到,按照我们定义的VMSS自动扩展规则,虚拟机开始自动增加:
12. 使用不同的浏览器测试网站,还会看到网站请求会被分发到新建立的服务器B,C,F等等,说明自动扩展集正在增加web服务器的时候,也会自动更新负载均衡器的设置,让前端客户的请求按照默认的哈希规则分发给后端的服务器,实现动态的负载均衡:
13. 压力测试完成,虚拟机扩展集的压力逐步低于50%,这个时候,整个虚拟机扩展集合会监测最近5分钟的负载情况,一旦满足收缩要求,就会执行cooldown的过程,逐步移除web服务器,也会从负载均衡器移除,降低成本:
通过这个测试可以看到,我们可以方便的使用VMSS+ARM快速的构建自动可扩展的web集群,并且使用定制化脚本部署我们的应用程序。
?
?
标签:
原文地址:http://www.cnblogs.com/cloudapps/p/5954851.html