使用ARM和VMSS创建自动扩展的web集群
在很多的商业场景中,用户的访问,峰值时间都是很难预测的,尤其是做一些市场推广活动和促销的时候,到底部署什么规模的web集群合适,这一直是个问题,部署过量会造成高成本和资源不必要的浪费,部署过少,如果到达峰值,来不及部署,容易造成用户无法访问,用户体验差,交易损失等等,当然更不用提运维人员时刻神经紧绷的实时监测压力情况,以便及时采取措施……
在云计算技术日新月异的今天,这个场景是非常不和谐的:)VMSS作为Azure新的计算方式,提供了按照压力负载自动扩展收缩,并且同时支持Windows和Linux,在提供了IAAS级别的控制灵活性的同时,也提供了PAAS级别的自动扩展,对于无状态的web服务器应用等场景非常适合,本文介绍如何通过ARM模板和VMSS创建一个自动负载均衡的,按照你的CPU负载自动扩展的web服务器集群:

在本模板中,将会创建如下测试环境:
- 定义一个负载均衡器,负责转发前端的web请求给后端的web集群
- 使用VMSS创建一个web集群
- 使用客户定制化脚本,自动安装Apache web服务器,和PHP web应用
- 定义自动扩展集合的规则,根据虚拟机自动扩展集合中的CPU负载进行自动扩展或者收缩,虚拟机也会自动的在负载均衡器中自动添加或者删除
- 压力测试用具,可以使用LoadRunner,Apache AB等等,在本例中,使用PHP产生压力,达到CPU阈值要求
- 原始的ARM模版请参考Azure的quick start模版:
https://github.com/Azure/azure-quickstart-templates/tree/master/201-vmss-lapstack-autoscale
- 我修改过的,直接可以在Azure China上运行的模版如下:
https://github.com/kingliantop/azurelabs/tree/master/AzureChinaARMTemplate/vmss-lapstack-autoscale
模板定义:
- 对于VMSS的基本定义,前述文档已经介绍过,不在赘述,再次我们先看一下负载均衡器的定义,首先我们需要增加一个负载均衡器的资源,这个资源依赖于公共IP地址,前端地址就是公共IP地址:

- 接下来我们需要定义负载均衡的规则,前端的请求通过DNS或者公网IP地址进来以后,通过默认的地址分发给后端的IP资源池,协议是TCP,前端和后端端口都是标准的80端口,你也可以设置负载均衡器空闲超时时间,这个时间会决定你的连接空闲时长,最长可是设置为30分钟;因为我们后续主要配置的是http请求,所以主要设置一下针对80端口的探测,以此判断后端虚拟机是否健康:

- 为方便用户定制化部署,快速扩展,Azure提供了定制化脚本扩展,可以让你在虚拟机部署完成后,运行自定义的脚本,安装你自己软件,部署你自己的应用,具体的用法如下,你可以将你的应用放在Azure存储中,本例中放在了github上,然后执行bash,进行安装配置:

在本次测试中,提供了两个PHP web文件,一个是index.php,用来显示当前的web应用跑在哪个服务器上,另外一个是do_work.php用来给web服务器产生压力,触发自动扩展。
- 最后需要配置一下VMSS自动扩展的规则,在什么情况下进行自动扩展,在什么情况下,进行自动收缩,在本例中,我们定义整个VMSS中平均CPU的负载在过去5分钟内高于60%就进行自动扩展,低于50%的时候自动收缩:

- 最后我们需要配置一下参数文件,定义一下VMSS的名称,初始在VMSS中需要几个虚拟机,用户名和密码即可:

- 最后,我们使用Powershell进行部署,我已经写好了一个deploy.ps1文件,大家在Powershell下修改下参数,直接执行即可,比如你希望的资源组名称,部署的区域等参数,然后在Powershell下执行即可:
#用你的Azure账号登陆
Login-AzureRmAccount -EnvironmentName AzureChinaCloud
#执行部署脚本

- 部署完成后,登陆Azure新portal,https://portal.azure.cn, 可以看到新的VMSS集合已经部署成功,包括有一个扩展集,,一个负载均衡器,一个公网IP地址及多个用于分发VM的存储账号:

- 打开虚拟机扩展集,,查看当前实例,可以看到当前有2个实例:

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集群,并且使用定制化脚本部署我们的应用程序。
使用ARM和VMSS创建自动扩展的web集群的更多相关文章
- suse 12 二进制部署 Kubernetets 1.19.7 - 第01章 - 创建CA证书和kubectl集群管理命令
文章目录 1.kubernetes集群部署 1.0.创建CA证书和秘钥 1.0.0.安装cfssl工具 1.0.1.创建根证书 1.0.2.创建证书签名请求文件 1.0.3.生成CA证书和秘钥 1.0 ...
- 使用Docker构建持续集成与自动部署的Docker集群
为什么使用Docker " 从我个人使用的角度讲的话 部署来的更方便 只要构建过一次环境 推送到镜像仓库 迁移起来也是分分钟的事情 虚拟化让集群的管理和控制部署都更方便 hub.docke ...
- docker镜像创建redis5.0.3容器集群
拉取redis5.0.3镜像 # docker pull daocloud.io/library/redis:5.0.3 [root@localhost ~]# docker pull daoclou ...
- 使用ARM模板在Azure中国大规模部署DCOS集群
容器技术是目前非常流行的技术,尤其是在以Docker作为容器引擎的推动下,让容器的轻量级,可移植,自包含,隔离性等的上了一个新的台阶,目前谈及Dev/Ops,CI/CD很少能够绕过Docker的. A ...
- AWS上创建EKS(K8S)集群
1.注意事项及准备工作 EKS分为EKS Master和EKS Node两种角色;EKS Master为全托管,EKS Node为CloudFormation创建 EKS Node若在NAT网络里,一 ...
- SpringCloud02 Eureka知识点、Eureka服务端和客户端的创建、Eureka服务端集群、Eureka客户端向集群的Eureka服务端注册
1 Eureka知识点 按照功能划分: Eureka由Eureka服务端和Eureka客户端组成 按照角色划分: Eureka由Eureka Server.Service Provider.Servi ...
- 使用Patroni和HAProxy创建高可用的PostgreSQL集群
操作系统:CentOS Linux release 7.6.1810 (Core) node1:192.168.216.130 master node2:192.168.216.132 slave n ...
- kubernetes之二 使用minikube创建单节点k8s本地集群
使用Minikube来运行kubernetes集群是最简单.快捷的途径.Minikube是一个构建单节点集群的工具,对于测试Kubernetes和本地开发应用都非常有用.官方安装minikube教程请 ...
- kubernetes 创建用户配置文件来访问集群API
创建一个账号 kubectl create serviceaccount def-ns-admin 绑定集群权限 kubectl create rolebinding def-ns-admin --c ...
随机推荐
- documentElement vs body
document.documentElement与document.body. 2011-03-12 10:15:46| 分类: javascript|字号 订阅 这是DOMDocument ...
- Qt Lite
http://blog.qt.io/blog/2016/08/18/introducing-the-qt-lite-project-qt-for-any-platform-any-thing-any- ...
- CSS中display:block的使用介绍
在CSS的规定中,每个页面元素都有一个display的属性,用于确定这个元素的类型是行内元素,还是块级元素: (1)行内元素:元素在一行内水平排列,依附于其他块级元素存在,因此,对行内元素设置高度.宽 ...
- 解决比较Oracle中CLOB字段问题
解决比较Oracle中CLOB字段问题 Oracle中CLOB和BLOB字段虽说在开发中满足了存放超大内容的要求,但是在一些简单使用中确频频带来麻烦.CLOB中存放的是指针,并不能直接取到实际值. ...
- .net常考面试题
1. 简述 private. protected. public. internal 修饰符的访问权限. 答 . private : 私有成员, 在类的内部才可以访问. protected : 保护成 ...
- PHP常用魔术方法(__set、__get魔术方法:)
__set.__get魔术方法: //文件名:Object.php <?phpnamespace IMooc;class Object{ protected $array = array(); ...
- iOS 原生二维码扫描,带扫描框和扫描过程动画
在代码中使用了相对布局框架Masonry 准备两张图片,一张是扫描边框,一张是扫描时的细线分别命名 scanFrame.png和scanLine.png并提前放入工程 导入相对布局头文件 #defin ...
- GitHub上可能用到的开源
AGi18n :https://github.com/angelolloqui/AGi18n 可以简单地本地化你的iOS app,从代码和XIB文件中提取文本转化成可本地化的字符串,且不会改变XIB文 ...
- JavaScript 判断一个字符串是否在另一个字符串中
传统上,JavaScript只有indexOf方法,可以用来确定一个字符串是否包含在另一个字符串中.ES6又提供了三种新方法. includes():返回布尔值,表示是否找到了参数字符串. start ...
- Building bridges_hdu_4584(排序).java
Building bridges Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) ...