Interface ICfnAutoScalingRollingUpdate
To specify how AWS CloudFormation handles rolling updates for an Auto Scaling group, use the AutoScalingRollingUpdate policy.
Namespace: Amazon.CDK
Assembly: Amazon.CDK.Lib.dll
Syntax (csharp)
public interface ICfnAutoScalingRollingUpdate
Syntax (vb)
Public Interface ICfnAutoScalingRollingUpdate
Remarks
Rolling updates enable you to specify whether AWS CloudFormation updates instances that are in an Auto Scaling group in batches or all at once.
ExampleMetadata: fixture=_generated
Examples
// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
using Amazon.CDK;
var cfnAutoScalingRollingUpdate = new CfnAutoScalingRollingUpdate {
MaxBatchSize = 123,
MinInstancesInService = 123,
MinSuccessfulInstancesPercent = 123,
PauseTime = "pauseTime",
SuspendProcesses = new [] { "suspendProcesses" },
WaitOnResourceSignals = false
};
Synopsis
Properties
MaxBatchSize | Specifies the maximum number of instances that AWS CloudFormation updates. |
MinInstancesInService | Specifies the minimum number of instances that must be in service within the Auto Scaling group while AWS CloudFormation updates old instances. |
MinSuccessfulInstancesPercent | Specifies the percentage of instances in an Auto Scaling rolling update that must signal success for an update to succeed. |
PauseTime | The amount of time that AWS CloudFormation pauses after making a change to a batch of instances to give those instances time to start software applications. |
SuspendProcesses | Specifies the Auto Scaling processes to suspend during a stack update. |
WaitOnResourceSignals | Specifies whether the Auto Scaling group waits on signals from new instances during an update. |
Properties
MaxBatchSize
Specifies the maximum number of instances that AWS CloudFormation updates.
virtual Nullable<double> MaxBatchSize { get; }
Property Value
System.Nullable<System.Double>
MinInstancesInService
Specifies the minimum number of instances that must be in service within the Auto Scaling group while AWS CloudFormation updates old instances.
virtual Nullable<double> MinInstancesInService { get; }
Property Value
System.Nullable<System.Double>
MinSuccessfulInstancesPercent
Specifies the percentage of instances in an Auto Scaling rolling update that must signal success for an update to succeed.
virtual Nullable<double> MinSuccessfulInstancesPercent { get; }
Property Value
System.Nullable<System.Double>
Remarks
You can specify a value from 0 to 100. AWS CloudFormation rounds to the nearest tenth of a percent. For example, if you update five instances with a minimum successful percentage of 50, three instances must signal success.
If an instance doesn't send a signal within the time specified in the PauseTime property, AWS CloudFormation assumes that the instance wasn't updated.
If you specify this property, you must also enable the WaitOnResourceSignals and PauseTime properties.
PauseTime
The amount of time that AWS CloudFormation pauses after making a change to a batch of instances to give those instances time to start software applications.
virtual string PauseTime { get; }
Property Value
System.String
Remarks
For example, you might need to specify PauseTime when scaling up the number of instances in an Auto Scaling group.
If you enable the WaitOnResourceSignals property, PauseTime is the amount of time that AWS CloudFormation should wait for the Auto Scaling group to receive the required number of valid signals from added or replaced instances. If the PauseTime is exceeded before the Auto Scaling group receives the required number of signals, the update fails. For best results, specify a time period that gives your applications sufficient time to get started. If the update needs to be rolled back, a short PauseTime can cause the rollback to fail.
Specify PauseTime in the ISO8601 duration format (in the format PT#H#M#S, where each # is the number of hours, minutes, and seconds, respectively). The maximum PauseTime is one hour (PT1H).
SuspendProcesses
Specifies the Auto Scaling processes to suspend during a stack update.
virtual string[] SuspendProcesses { get; }
Property Value
System.String[]
Remarks
Suspending processes prevents Auto Scaling from interfering with a stack update. For example, you can suspend alarming so that Auto Scaling doesn't execute scaling policies associated with an alarm. For valid values, see the ScalingProcesses.member.N parameter for the SuspendProcesses action in the Auto Scaling API Reference.
WaitOnResourceSignals
Specifies whether the Auto Scaling group waits on signals from new instances during an update.
virtual Nullable<bool> WaitOnResourceSignals { get; }
Property Value
System.Nullable<System.Boolean>
Remarks
Use this property to ensure that instances have completed installing and configuring applications before the Auto Scaling group update proceeds. AWS CloudFormation suspends the update of an Auto Scaling group after new EC2 instances are launched into the group. AWS CloudFormation must receive a signal from each new instance within the specified PauseTime before continuing the update. To signal the Auto Scaling group, use the cfn-signal helper script or SignalResource API.
To have instances wait for an Elastic Load Balancing health check before they signal success, add a health-check verification by using the cfn-init helper script. For an example, see the verify_instance_health command in the Auto Scaling rolling updates sample template.