Powershell AWS 自动化管理(5)- ELB and Auto Scaling

简介:

这一节豆子来看看如何使用PowerShell来配置ELB和Auto Scaling。ELB给多台服务器提供了负载均衡,而Auto Scaling可以根据负载动态的在ELB的集群里增加或者减少服务器。


具体的图像界面的配置方法可以参考这个

http://beanxyz.blog.51cto.com/5570417/1536261



下面看看命令行的实现方式,我们需要配置以下服务和组件

  1. ELB

  2. 自定义的镜像文件

  3. 创建AS Group的配置文件

  4. 创建AS Group

  5. 创建Alarm,实现动态增减




首先看看ELB的配置。


例如下面的脚本:

他会监听80端口,指定ELB分布在子网10.2.1.0/24 和 10.2.2.0/24上面,Security Group是NewSG,并加入一个EC2的实例 test。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#Create ELB
$HTTPListener  New-Object  -TypeName ‘Amazon.ElasticLoadBalancing.Model.Listener’
$HTTPListener .Protocol = ‘http’
$HTTPListener .InstancePort = 80
$HTTPListener .LoadBalancerPort = 80
$groupid =( Get-EC2SecurityGroup where-object  { $_ .GroupName  -eq  "NewSG" }).GroupId
$subnet1 =( Get-EC2Subnet  Where-Object  { $_ .CidrBlock  -eq  "10.2.1.0/24" }).SubnetId
$subnet2 =( Get-EC2Subnet  Where-Object  { $_ .CidrBlock  -eq  "10.2.2.0/24" }).SubnetId
New-ELBLoadBalancer  -LoadBalancerName  "MyLoadBalance"  -Listener  $HTTPListener  -SecurityGroup  $groupid  -Subnet @( $subnet1 , $subnet2
$instnaces = Get-EC2Instance
foreach  ( $i  in  $instnaces ){
     if ( $i .instances.tags.value  -eq  “test”){
         $instance2Id = $i .instances.instanceid
     
     }
}
Register-ELBInstanceWithLoadBalancer  -LoadBalancerName  "MyLoadBalance"  -Instance @( $instance2Id )



配置了ELB之后,我们接下来配置Auto Scaling, 首先需要根据当前准备好的虚拟机生成一个镜像文件。


比如

1
2
3
4
5
6
7
8
9
10
#Images
$instnaces = Get-EC2Instance
foreach  ( $i  in  $instnaces ){
     if ( $i .instances.tags.value  -eq  “Linux”){
         $instanceId = $i .instances.instanceid
     
     }
}
New-EC2Image  -Description TemplateTest -Name Template -InstanceId  $instanceId
Get-EC2Image  -Owner self |  Unregister-EC2Image  -PassThru


生成镜像文件之后,我需要创建一个launch configuration 文件,绑定这个镜像和相关的子网。



1
2
3
#Create Auto Scaling Policy and Group
Get-ASAutoScalingGroup
New-ASLaunchConfiguration  -ImageId ( Get-EC2Image  -Owner self).imageid -LaunchConfigurationName  "My-launchconfigurationfile"  -InstanceType  "t2.micro"  -SecurityGroup  $groupid


最后再配置一个基本的AutoScalingGroup,绑定上面的launch configuration 文件就可以了。注意绑定的security group和子网都要在一个范围里面,不然他会报错无法生成EC2实例。


1
2
3
4
New-ASAutoScalingGroup  -AutoScalingGroupName  "my-asg"  -LaunchConfigurationName  "My-launchconfigurationfile"  -MinSize 1 -MaxSize 3 -LoadBalancerName  "MyLoadBalance"  -AvailabilityZone @( "ap-southeast-2c" ) `
-VPCZoneIdentifier  $subnet1
Write-ASScalingPolicy  -AutoScalingGroupName my-asg -AdjustmentType  "ChangeInCapacity"  -PolicyName  "myScaleInPolicy"  -ScalingAdjustment 1 
Remove-ASAutoScalingGroup  -AutoScalingGroupName  "my-asg"


因为我指定了至少要1个实例,因此他会自动在ELB里面给我创建一个


wKiom1d6CZWChajRAAB5e8K1d8Q400.png



如果熟悉auto scaling group的话,可以看见我创建的这个policy过于简单,缺少一个alarm的触发器。


wKioL1d6CmWR2StsAADCflHoudk047.png


为什么呢,这是因为我没有指定他的policytype,默认的情况下是作为simpleScaling来处理的。

如果希望设置成动态的变化,需要指定类型为StepScaling, 然后在CloudWatch里面创建对应的Alarm,然后将Alarm绑定到指定的AutoScalingGroup里面才行。


例如,注意那个alarmaction后面跟的字符串是上一步创建的ASGroup生成的arn的号码,如果需要通过sns触发邮件,也可以直接把对应的sns arn加进去进行了。

1
2
3
4
5
6
$stepadjustment = New-Object  Amazon.AutoScaling.Model.StepAdjustment 
$stepadjustment .MetricIntervalLowerBound=20
$stepadjustment .ScalingAdjustment=-1
Write-ASScalingPolicy  -AutoScalingGroupName my-asg -AdjustmentType  "ChangeInCapacity"  -PolicyName  "myScaleInPolicy1"  -PolicyType  "StepScaling"  -StepAdjustment  $stepadjustment
Write-CWMetricAlarm  -ActionsEnabled  $true  -Alarmname  "testonly"  -AlarmAction {arn:aws:autoscaling:ap-southeast-2:503646143282:scalingPolicy:fba2d6ec-1566-459a-a3d5-bb800e88f7ad:autoScalingGroupName/my-asg:policyName/myScaleInPolicy1} -Namespace  "AWS/EC2"  -Period 300 -Statistic  "Average"  -MetricName  "CPUUtlilization"  `
-ComparisonOperator  "LessThanOrEqualToThreshold"  -Threshold 60 -EvaluationPeriod 1

结果如下

wKiom1d7Fb-grETGAABqVGLp2O8163.png


最后,豆子吐槽一下AWS的模块命令。

这个auto scaling group创建对应的的policy和alarm很让我花了翻功夫。 因为aws不知道出于什么原因,估计开发人员属于不同的小组,他的创建命令是write-asscalingpolicy,而对应的读取命令是 get-aspolicy, 删除命令是remove-aspolicy, 完全不符合命名规范,也给使用者查找造成了困难!AWS PowerShell 的使用在网上几乎没有太多第三方的资料,而AWS相关的帮助文档仅仅给出来语法格式和最最简单的配置例子。 而且最可恶的是,他的SDK里面明明有Alarm这个属性成员,但是这个write-asscalingpolicy这个创建命令却不提供这个参数进行配置。折腾了2个小时,豆子终于在cloudwatch里面找到了配置命令并成功的绑定到ASGroup。此外,在过去的几天使用情况里,存在大量的情况,需要使用New-Object实例化新的对象来传入参数,这种使用方式更像是.Net的开发习惯,而在PowerShell日常使用的频率并不太高。






本文转自 beanxyz 51CTO博客,原文链接:http://blog.51cto.com/beanxyz/1795603,如需转载请自行联系原作者

相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
5月前
|
SQL Java BI
有什么好用的企业自动化管理开源软件
有什么好用的企业自动化管理开源软件
|
5月前
|
存储 运维 数据中心
Terraform的自动化管理
Terraform的自动化管理
26 0
|
5月前
|
缓存 Kubernetes 容器
OpenKruise是阿里云开源的大规模应用自动化管理引擎
OpenKruise是阿里云开源的大规模应用自动化管理引擎
352 2
|
10月前
Retrofit实现cookie自动化管理
Retrofit实现cookie自动化管理
63 0
|
11月前
|
JavaScript 测试技术 开发工具
从0搭建vue3组件库:自动化发布、管理版本号、生成 changelog、tag
从0搭建vue3组件库:自动化发布、管理版本号、生成 changelog、tag
244 0
|
11月前
|
机器学习/深度学习 存储 文字识别
【增值税发票识别 OCR】如何实现自动化发票管理
通过利用增值税发票识别OCR API 实现智能化的增值税发票识别、分类和归档,企业可以实现自动化的发票管理流程。这将大大提高工作效率、减少错误率,并为企业提供准确的财务数据和统计分析基础,有需要的小伙伴赶紧用起来吧~
181 0
【增值税发票识别 OCR】如何实现自动化发票管理
|
24天前
|
数据采集 存储 API
网络爬虫与数据采集:使用Python自动化获取网页数据
【4月更文挑战第12天】本文介绍了Python网络爬虫的基础知识,包括网络爬虫概念(请求网页、解析、存储数据和处理异常)和Python常用的爬虫库requests(发送HTTP请求)与BeautifulSoup(解析HTML)。通过基本流程示例展示了如何导入库、发送请求、解析网页、提取数据、存储数据及处理异常。还提到了Python爬虫的实际应用,如获取新闻数据和商品信息。
|
2月前
|
Web App开发 Python
在ModelScope中,你可以使用Python的浏览器自动化库
在ModelScope中,你可以使用Python的浏览器自动化库
18 2
|
2月前
|
存储 BI 数据处理
Python自动化 | 解锁高效办公利器,Python助您轻松驾驭Excel!
Python自动化 | 解锁高效办公利器,Python助您轻松驾驭Excel!

热门文章

最新文章