Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/awslabs/ami-builder-packer
An example of an AMI Builder using CI/CD with AWS CodePipeline, AWS CodeBuild, Hashicorp Packer and Ansible.
https://github.com/awslabs/ami-builder-packer
Last synced: 3 months ago
JSON representation
An example of an AMI Builder using CI/CD with AWS CodePipeline, AWS CodeBuild, Hashicorp Packer and Ansible.
- Host: GitHub
- URL: https://github.com/awslabs/ami-builder-packer
- Owner: awslabs
- License: apache-2.0
- Archived: true
- Created: 2017-04-18T20:00:07.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2019-05-28T10:39:46.000Z (over 5 years ago)
- Last Synced: 2024-08-01T22:05:42.363Z (7 months ago)
- Size: 729 KB
- Stars: 463
- Watchers: 74
- Forks: 232
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Purpose
This Packer AMI Builder creates a new AMI out of the latest Amazon Linux AMI, and also provides a cloudformation template that leverages AWS CodePipeline to
orchestrate the entire process.data:image/s3,"s3://crabby-images/43703/437037f2886269141d2f0941e698f189f368af2e" alt="Packer AMI Builder Diagram"
## Source code structure
```bash
├── ansible
│ ├── playbook.yaml <-- Ansible playbook file
│ ├── requirements.yaml <-- Ansible Galaxy requirements containing additional Roles to be used (CIS, Cloudwatch Logs)
│ └── roles
│ ├── common <-- Upgrades all packages through ``yum``
├── buildspec.yml <-- CodeBuild spec
├── cloudformation <-- Cloudformation to create entire pipeline
│ └── pipeline.yaml
├── packer_cis.json <-- Packer template for Pipeline
```## Cloudformation template
Cloudformation will create the following resources as part of the AMI Builder for Packer:
* ``cloudformation/pipeline.yaml``
+ AWS CodeCommit - Git repository
+ AWS CodeBuild - Downloads Packer and run Packer to build AMI
+ AWS CodePipeline - Orchestrates pipeline and listen for new commits in CodeCommit
+ Amazon SNS Topic - AMI Builds Notification via subscribed email
+ Amazon Cloudwatch Events Rule - Custom Event for AMI Builder that will trigger SNS upon AMI completion## HOWTO
**Before you start**
* Install [GIT](https://git-scm.com/downloads) if you don't have it
* Make sure AWS CLI is configured properly
* [Configured AWS CLI and Git](http://docs.aws.amazon.com/codecommit/latest/userguide/setting-up-https-unixes.html) to connect to AWS CodeCommit repositories**Launch the Cloudformation stack**
Region | AMI Builder Launch Template
------------------------------------------------- | ---------------------------------------------------------------------------------
N. Virginia (us-east-1) | [data:image/s3,"s3://crabby-images/89b94/89b9496acdf745ec0b484582a728c89aeb43540b" alt="Launch Stack"](https://console.aws.amazon.com/cloudformation/home?region=us-east-1#/stacks/new?stackName=AMI-Builder-Blogpost&templateURL=https://s3-eu-west-1.amazonaws.com/ami-builder-packer/cloudformation/pipeline.yaml)
Ireland (eu-west-1) | [data:image/s3,"s3://crabby-images/89b94/89b9496acdf745ec0b484582a728c89aeb43540b" alt="Launch Stack"](https://console.aws.amazon.com/cloudformation/home?region=eu-west-1#/stacks/new?stackName=AMI-Builder-Blogpost&templateURL=https://s3-eu-west-1.amazonaws.com/ami-builder-packer/cloudformation/pipeline.yaml)
London (eu-west-2) | [data:image/s3,"s3://crabby-images/89b94/89b9496acdf745ec0b484582a728c89aeb43540b" alt="Launch Stack"](https://console.aws.amazon.com/cloudformation/home?region=eu-west-2#/stacks/new?stackName=AMI-Builder-Blogpost&templateURL=https://s3-eu-west-1.amazonaws.com/ami-builder-packer/cloudformation/pipeline.yaml)**To clone the AWS CodeCommit repository (console)**
1. From the AWS Management Console, open the AWS CloudFormation console.
2. Choose the AMI-Builder-Blogpost stack, and then choose Output.
3. Make a note of the Git repository URL.
4. Use git to clone the repository.
For example: git clone https://git-codecommit.eu-west-1.amazonaws.com/v1/repos/AMI-Builder_repo**To clone the AWS CodeCommit repository (CLI)**
```bash
# Retrieve CodeCommit repo URL
git_repo=$(aws cloudformation describe-stacks --query 'Stacks[0].Outputs[?OutputKey==`GitRepository`].OutputValue' --output text --stack-name "AMI-Builder-Blogpost")# Clone repository locally
git clone ${git_repo}
```Next, we need to copy all files in this repository into the newly cloned Git repository:
* Download [ami-builder-packer ZIP](https://github.com/awslabs/ami-builder-packer/archive/master.zip).
* Extract and copy the contents to the Git repoLastly, commit these changes to your AWS CodeCommit repo and watch the AMI being built through the AWS CodePipeline Console:
```bash
git add .
git commit -m "SHIP THIS AMI"
git push origin master
```data:image/s3,"s3://crabby-images/17043/17043b855c531f5debb8c7ab18673945128cd4db" alt="AWS CodePipeline Console - AMI Builder Pipeline"
## Known issues
* ~~Currently, Packer doesn't work with ECS IAM Roles (also used by CodeBuild)~~
- ~~That's why we build a credentials file that leverages temporary credentials in the ``buildspec``~~
- ~~When Packer supports this feature, this will no longer be necessary~~
* If Build process fails and within AWS CodeBuild Build logs you find the following line ``Timeout waiting for SSH.``, it means either
- A) You haven't chosen a VPC Public Subnet, and therefore Packer cannot connect to the instance
- B) There may have been a connectivity issue between Packer and EC2; retrying the build step within AWS CodePipeline should work just fine