- unmigrated-wiki-markup
Documentation for Tasks for AWS 2.10 – other releases are available in the Tasks for AWS Documentation Directory.
View
or visit the current documentation home.
Deploying to AWS Elastic Beanstalk
Workflow
The deployment workflow is illustrated by the diagram in What Is AWS Elastic Beanstalk?:
The binding between those components is established indirectly and comprises the following activities:
- create an application – see the Create Application action of the AWS Elastic Beanstalk Application task
- upload the application source code (the 'Source Bundle') – see the Upload File(s) action of the Amazon S3 Object task
- create an application version for that application – see the Create Application Version action of the AWS Elastic Beanstalk Application Version task
- launch an environment with one of the available application versions of an application – see the Create Environment action of the AWS Elastic Beanstalk Environment task
- manage the environment, which implies going back to 3./4. and selecting one of two approaches for deploying a new application version (be it a newly created or a former one):
- update an environment by deploying a new application version that replaces the currently running one (usually via a rolling update), as outlined in Deploying Applications to AWS Elastic Beanstalk Environments – see the Update Environment action of the AWS Elastic Beanstalk Environment task
create a new environment, optionally swapping over to that one with zero downtime, as outlined in Blue/Green Deployments with AWS Elastic Beanstalk – see the Swap Environment CNAMEs action of the AWS Elastic Beanstalk Environment task
AWS recommends rolling updates
If your application architecture and deployment scenario allow to use rolling updates, AWS nowadays recommends this approach over a CNAME swap – refer to Deploying Applications to AWS Elastic Beanstalk Environments for a comparison of available deployment methods.
Alternative workflow via CloudFormation
As an alternative to using the AWS Elastic Beanstalk tasks built into Tasks for AWS, it is also possible to provision the Elastic Beanstalk components directly via the AWS CloudFormation Stack task and the corresponding CloudFormation resource types:
A typical workflow based on CloudFormation might look as follows:
- upload the application source code (the 'Source Bundle') – see the Upload File(s) action of the Amazon S3 Object task
- create/update the CloudFormation stack that provisions the Elastic Beanstalk application, application version and environment – see the Create Stack action of the AWS CloudFormation Stack task
- You can use the Update stack, if it already exists option to reuse the same Bamboo job for both actions