这一节豆子来看看如何使用PowerShell来配置ELB和Auto Scaling。ELB给多台服务器提供了负载均衡,而Auto Scaling可以根据负载动态的在ELB的集群里增加或者减少服务器。
具体的图像界面的配置方法可以参考这个
http://beanxyz.blog.51cto.com/5570417/1536261
下面看看命令行的实现方式,我们需要配置以下服务和组件
ELB
自定义的镜像文件
创建AS Group的配置文件
创建AS Group
创建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里面给我创建一个
如果熟悉auto scaling group的话,可以看见我创建的这个policy过于简单,缺少一个alarm的触发器。
为什么呢,这是因为我没有指定他的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
|
结果如下
最后,豆子吐槽一下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日常使用的频率并不太高。