Migrate Amazon CloudFormation stacks to launch templates
You can migrate your existing Amazon CloudFormation stack templates from launch configurations to launch templates. To do this, add a launch template directly to an existing stack template and then associate the launch template with the Auto Scaling group in the stack template. Then, use your modified template to update your stack.
When migrating to launch templates, this topic saves you time by providing instructions for rewriting the launch configurations in your CloudFormation stack templates as launch templates. For more information about migrating launch configurations to launch templates, see Migrate your Auto Scaling groups to launch templates.
Topics
Find Auto Scaling groups that use a launch configuration
To find Auto Scaling groups that use a launch configuration
-
Use the following describe-auto-scaling-groups command to list the names of Auto Scaling groups that are using launch configurations in the specified Region. Include the
--filters
option to narrow the results to groups associated with a CloudFormation stack (by filtering by theaws:cloudformation:stack-name
tag key).aws autoscaling describe-auto-scaling-groups --region
REGION
\ --filters Name=tag-key,Values=aws:cloudformation:stack-name \ --query 'AutoScalingGroups[?LaunchConfigurationName!=`null`].AutoScalingGroupName'The following shows example output.
[ "{stack-name}-group-1", "{stack-name}-group-2", "{stack-name}-group-3" ]
You can find additional useful Amazon CLI commands for finding Auto Scaling groups to migrate and filtering the output in Migrate your Auto Scaling groups to launch templates.
Important
If your stack resources have AWSEB
in their name, this means they
were created through Amazon Elastic Beanstalk. In this case, you must update the Beanstalk
environment to direct Elastic Beanstalk to remove the launch configuration and replace it
with a launch template.
Update a stack to use a launch template
Follow the steps in this section to do the following:
-
Rewrite the launch configuration as a launch template using the equivalent launch template properties.
-
Associate the new launch template with the Auto Scaling group.
-
Deploy these updates.
To modify the stack template and update the stack
-
Follow the same general procedures for modifying the stack template described in Modifying a stack template in the Amazon CloudFormation User Guide.
-
Rewrite the launch configuration as a launch template. See the following example:
Example: A simple launch configuration
--- Resources: myLaunchConfig: Type: AWS::AutoScaling::LaunchConfiguration Properties: ImageId: ami-02354e95b3example InstanceType: t3.micro SecurityGroups: - !Ref EC2SecurityGroup KeyName: MyKeyPair BlockDeviceMappings: - DeviceName: /dev/xvda Ebs: VolumeSize: 150 DeleteOnTermination: true UserData: Fn::Base64: !Sub | #!/bin/bash -xe yum install -y aws-cfn-bootstrap /opt/aws/bin/cfn-signal -e $? --stack ${AWS::StackName} --resource myASG --region ${AWS::Region}
Example: The launch template equivalent
--- Resources: myLaunchTemplate: Type: AWS::EC2::LaunchTemplate Properties: LaunchTemplateName:
!Sub ${AWS::StackName}-launch-template
LaunchTemplateData: ImageId: ami-02354e95b3example InstanceType: t3.micro SecurityGroupIds: - Ref! EC2SecurityGroup KeyName: MyKeyPair BlockDeviceMappings: - DeviceName: /dev/xvda Ebs: VolumeSize: 150 DeleteOnTermination: true UserData: Fn::Base64: !Sub | #!/bin/bash -x yum install -y aws-cfn-bootstrap /opt/aws/bin/cfn-signal -e $? --stack ${AWS::StackName} --resource myASG --region ${AWS::Region}For reference information for all the properties that Amazon EC2 supports, see AWS::EC2::LaunchTemplate in the Amazon CloudFormation User Guide.
Note how the launch template includes the
LaunchTemplateName
property with a value of!Sub ${AWS::StackName}-launch-template
. This is required if you want the name of the launch template to include the stack name. -
If the
IamInstanceProfile
property is present in your launch configuration, you must convert it to a structure and specify either the name or the ARN of the instance profile. For an example, see AWS::EC2::LaunchTemplate. -
If the
AssociatePublicIpAddress
,InstanceMonitoring
, orPlacementTenancy
properties are present in your launch configuration, you must convert these to a structure. For examples, see AWS::EC2::LaunchTemplate.An exception is when the value for the
MapPublicIpOnLaunch
property on the subnets you used for your Auto Scaling group matches the value for theAssociatePublicIpAddress
property in your launch configuration. In this case, you can ignore theAssociatePublicIpAddress
property. TheAssociatePublicIpAddress
property is only used to override theMapPublicIpOnLaunch
property to change whether instances receive a public IPv4 address at launch. -
You can copy security groups from the
SecurityGroups
property to one of two places in your launch template. Normally, you copy the security groups to theSecurityGroupIds
property. However, if you create aNetworkInterfaces
structure within your launch template to specify theAssociatePublicIpAddress
property, then you must copy the security groups to theGroups
property of the network interface instead. -
If any
BlockDeviceMapping
structures are present in your launch configuration withNoDevice
set totrue
, then you must specify an empty string forNoDevice
in your launch template to have Amazon EC2 omit the device. -
If the
SpotPrice
property is present in your launch configuration, we recommend that you omit it from your launch template. Your Spot Instances will launch at the current Spot price. This price will never exceed the On-Demand price.To request Spot Instances, you have two mutually exclusive options:
-
The first is to use the
InstanceMarketOptions
structure in your launch template (not recommended). For more information, see AWS::EC2::LaunchTemplate InstanceMarketOptions in the Amazon CloudFormation User Guide. -
The other is to add a
MixedInstancesPolicy
structure to your Auto Scaling group. Doing so provides you with more options for how you make the request. A Spot Instance request in your launch template doesn't support more than one instance type selection per Auto Scaling group. However, a mixed instances policy does support more than one instance type selection per Auto Scaling group. Spot Instance requests benefit from having more than one instance type to choose from. For more information, see AWS::AutoScaling::AutoScalingGroup MixedInstancesPolicy in the Amazon CloudFormation User Guide.
-
-
Remove the
LaunchConfigurationName
property from the AWS::AutoScaling::AutoScalingGroup resource. Add the launch template in its place.In the following examples, the Ref intrinsic function gets the ID of the AWS::EC2::LaunchTemplate resource with the logical ID
myLaunchTemplate
. The GetAtt function gets the latest version number (for example,1
) of the launch template for theVersion
property.Example: Without a mixed instances policy
--- Resources: myASG: Type: AWS::AutoScaling::AutoScalingGroup Properties: LaunchTemplate: LaunchTemplateId:
!Ref myLaunchTemplate
Version:!GetAtt myLaunchTemplate.LatestVersionNumber
...Example: With a mixed instances policy
--- Resources: myASG: Type: AWS::AutoScaling::AutoScalingGroup Properties: MixedInstancesPolicy: LaunchTemplate: LaunchTemplateSpecification: LaunchTemplateId:
!Ref myLaunchTemplate
Version:!GetAtt myLaunchTemplate.LatestVersionNumber
...For reference information for all the properties that Amazon EC2 Auto Scaling supports, see AWS::AutoScaling::AutoScalingGroup in the Amazon CloudFormation User Guide.
-
When you are ready to deploy these updates, follow the CloudFormation procedures to update the stack with your modified stack template. For more information, see Modifying a stack template in the Amazon CloudFormation User Guide.
Understand update behavior of stack resources
CloudFormation updates stack resources by comparing changes between the updated template you provide, and resource configurations you described in the previous version of your stack template. Resource configurations that haven't changed remain unaffected during the update process.
CloudFormation supports the UpdatePolicy attribute for Auto Scaling groups. During an update, if
UpdatePolicy
is set to AutoScalingRollingUpdate
,
CloudFormation replaces InService
instances after you perform the steps in
this procedure. If UpdatePolicy
is set to
AutoScalingReplacingUpdate
, CloudFormation replaces the Auto Scaling group and
its warm pool (if one exists).
If you didn't specify an UpdatePolicy
attribute for your Auto Scaling group,
the launch template is checked for correctness, but CloudFormation does not deploy any
change across the instances in the Auto Scaling group. All new instances will use your
launch template, but existing instances continue to run with the launch
configuration that they were originally launched with (despite the launch
configuration not existing). The exception is when you change your purchase options,
for example, by adding a mixed instances policy. In this case, your Auto Scaling group
gradually replaces the existing instances with new instances to match the new
purchase options.
Track the migration
To track the migration
-
In the Amazon CloudFormation console
, select the stack that you updated and then choose the Events tab to view the stacks events. -
To update the event list with the most recent events, choose the refresh button in the CloudFormation console.
-
While your stack is updating, you will notice multiple events for each resource update. If you see an exception in the Status reason column that indicates a problem when trying to create the launch template, see Troubleshoot Amazon EC2 Auto Scaling: Launch templates for potential causes.
-
(Optional) Depending on your use of the
UpdatePolicy
attribute, you can monitor the progress of your Auto Scaling group from the Auto Scaling groups pageof the Amazon EC2 console. Select the Auto Scaling group. On the Activity tab, under Activity history, the Status column shows whether your Auto Scaling group has successfully launched or terminated instances, or whether the scaling activity is still in progress. -
When the stack update is complete, CloudFormation issues an
UPDATE_COMPLETE
stack event. For more information, see Monitoring the progress of a stack update in the Amazon CloudFormation User Guide. -
After the stack update is complete, open the Launch templates page
and Launch configurations page of the Amazon EC2 console. You will notice a new launch template is created, and the launch configuration is deleted.
Launch configuration mapping reference
For reference purposes, the following table lists all the top-level properties in the AWS::AutoScaling::LaunchConfiguration resource with their corresponding property in the AWS::EC2::LaunchTemplate resource.
Launch configuration source property | Launch template target property |
---|---|
AssociatePublicIpAddress |
NetworkInterfaces.AssociatePublicIpAddress |
BlockDeviceMappings |
BlockDeviceMappings |
ClassicLinkVPCId |
Not available¹ |
ClassicLinkVPCSecurityGroups |
Not available¹ |
EbsOptimized |
EbsOptimized |
IamInstanceProfile |
Either IamInstanceProfile.Arn or
IamInstanceProfile.Name , but not both |
ImageId |
ImageId |
InstanceId |
InstanceId |
InstanceMonitoring |
Monitoring.Enabled |
InstanceType |
InstanceType |
KernelId |
KernelId |
KeyName |
KeyName |
LaunchConfigurationName |
LaunchTemplateName |
MetadataOptions |
MetadataOptions |
PlacementTenancy |
Placement.Tenancy
|
RamDiskId |
RamDiskId |
SecurityGroups |
Either SecurityGroupIds or
NetworkInterfaces.Groups , but not both |
SpotPrice |
InstanceMarketOptions.SpotOptions.MaxPrice |
UserData |
UserData |
¹ The ClassicLinkVPCId
and
ClassicLinkVPCSecurityGroups
properties are not available to use in
a launch template because EC2-Classic is no longer available.