You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository has been archived by the owner on Dec 2, 2022. It is now read-only.
Take all instructions from Setup forward and paste into a new "Issue" on your repository, this will allow you to check items off the list as they're completed and track your progress.
If you would not like to add the SE to the owner team, you can alternatively create a new team and make sure that team is added to all appropriate resources
Settings -> Your Organization -> "Teams" -> "Manage" or "Create" -> "Add user"
Note: Terraform creates real resources in AWS that cost money. Don't forget to destroy your PoC environment when finished to avoid unnecessary expenses.
Set Local Environment Variables
Set the below environment variables if you'll be using Packer or Terraform locally.
Note: The environment variable ATLAS_USERNAME can be set to your individual username or your
organization name in Atlas. Typically, this should be set to your organization name - e.g. hashicorp.
Generate Keys and Certs
There are certain resources in this project that require the use of keys and certs to validate identity, such as Terraform's remote-exec provisioners and TLS in Consul/Vault. For the sake of quicker & easier onboarding, we've created a gen_key.sh and gen_cert.sh script that can generate these for you.
Note: While using this for PoC purposes, these keys and certs should suffice. However, as you start to move your actual applications into this infrastructure, you'll likely want to replace these self-signed certs with certs that are signed by a CA and use keys that are created with your security principles in mind.
If you enter the path of an existing private key as an optional second parameter, it will create a public (.pub) key from the existing private (.pem) key specified (e.g. sh gen_key.sh site ~/.ssh/my-existing-private-key.pem)
This will generate a public (.pub) and private (.pem) key in the setup/. directory
Generate site and vault certs
Run sh gen_cert.sh YOUR_DOMAIN YOUR_COMPANY in setup (e.g. sh gen_cert.sh hashicorpdemo.com HashiCorp)
If you don't have a domain currently, you can make one up, or grab one from a service like NameCheap to do your testing on
This will generate 2 certs, one named site (external self-signed cert for browsers) and one named vault (internal self-signed cert for Consul/Vault TLS), both within the setup/. directory
Move all keys & certs created here out of the repository and into a secure location
No keys or certs should ever be checked into version control
Create and Configure Artifacts
Use the New Build Configuration tool to create each new Build Configuration below. Enter the names provided as you go through the checklist and be sure to leave the Automatically build on version uploads and Connect build configuration to a GitHub repository boxes unchecked for each.
After creating each Build Configuration, there is some additional configuration you'll need to do. The summary of what will need to be completed for each Build Configuration is below, the relevant values are provided as you go through the checklist.
Add Environment Variables
Go into "Variables" in the left navigation of the Build Configuration and set the below Environment Variables with their appropriate values
ATLAS_USERNAME
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_DEFAULT_REGION: us-east-1
Integrate with GitHub
Go into "Integrations" in the left navigation of the Build Configuration
Select the best-practices GitHub repository you just forked
Enter packer for Packer Directory
Enter the appropriate Packer template(provided below) and click Associate
Queue Build
You can then go to "Builds" in the left navigation of each of the Build Configuration(s) and click Queue build, this should create new artifact(s). You'll need to wait for the base artifact to be created before you queue any of the child builds as we take advantage of Base Artifact Variable Injection.
You do NOT want to queue builds for aws-us-east-1-ubuntu-nodejs because this Build Template will be used by the application. Queueing a build for aws-us-east-1-ubuntu-nodejswill fail with the error * Bad source 'app/': stat app/: no such file or directory.
Wait until the Base Artifact has been created before moving on to the child Build Configurations. These will fail with an error of * A source_ami must be specified until the Base Artifact has been created and selected.
For child Build Configurations, there is one additional step you need to take. In "Settings", set Inject artifact ID during build to aws-us-east-1-ubuntu-base for each.
Click Queue build in "Builds" for each of the below Build Configurations to create new artifacts for each (remember, we will not do this for aws-us-east-1-ubuntu-nodejs)
aws-us-east-1-ubuntu-consul
aws-us-east-1-ubuntu-vault
aws-us-east-1-ubuntu-haproxy
We built artifacts for the us-east-1 region in this walkthrough. If you'd like to add another region, follow the Multi-Region setup instructions below.
If you decide to update any of the artifact names, be sure those name changes are reflected in your terraform.tfvars file(s).
Use the New Application tool to create your Node.js Application
Choose a name for the application: aws-us-east-1-nodejs
Compile Application: checked
Build Template: aws-us-east-1-ubuntu-nodejs
Connect application to a GitHub repository
GitHub repository: demo-app-nodejs
Leave both Application directory and Application Template blank
Upload new versions of the application by merging a commit into master from your forked repo. This will upload your latest app code and trigger a Packer build to create a new compiled application artifact.
If you don't have a change to make, you can force an application ingress into Atlas with an empty commit.
$ git commit --allow-empty -m "Force a change in Atlas"
If you want to create artifacts in other regions, complete these same steps but select a Build Template from the region you'd like.
In "Settings": check Plan on artifact uploads and click Save
In "Variables": add the below Environment Variables with appropriate values
ATLAS_USERNAME
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_DEFAULT_REGION: us-east-1
TF_ATLAS_DIR: providers/aws/global
Atlas uses the TF_ATLAS_DIR variable to identify where it should run Terraform commands within the repo
In "Variables": update all Terraform variables containing the value REPLACE_IN_ATLAS
Update domain with your domain (e.g. hashicorpdemo.com)
If you don't have a domain currently, you can make one up, or grab one from a service like NameCheap to do your testing on
We use this domain to create S3 buckets to host a static website, so if you're making a domain up, try to make it unique to your company to avoid S3 bucket naming conflicts
Update atlas_username with your Atlas username
Update iam_admins with a comma separated list of users you'd like added to the admin group in IAM (e.g. cameron,jay,jon,kevin)
This is defaulted to a user named global-admin
Be sure that you don't use a name that already exists in IAM for this AWS account or you will see conflict errors
If you don't want any admin users to be created, just leave this blank
In "Integrations": under "GitHub Integration" click Update GitHub settings to pull the latest configuration from master
In "Changes": click Queue plan if one has not already been queued, then Confirm & Apply to provision the aws-global environment
In "Settings": check Plan on artifact uploads and click Save
In "Variables": add the below Environment Variables with appropriate values
ATLAS_USERNAME
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_DEFAULT_REGION: us-east-1
TF_ATLAS_DIR: providers/aws/us_east_1_prod
Atlas uses the TF_ATLAS_DIR variable to identify where it should run Terraform commands within the repo
In "Variables": update all Terraform Variables containing the value REPLACE_IN_ATLAS, you will use the contents of the keys and certs created in Generate Keys and Certs as values for most of these variables
Update atlas_token with your Atlas token
Update atlas_username with your Atlas username
Update site_public_key with the contents of site.pub
Update site_private_key with the contents of site.pem
Update site_ssl_cert with the contents of site.crt
Update site_ssl_key with the contents of site.key
Update vault_ssl_cert with the contents of vault.crt
Update vault_ssl_key with the contents of vault.key
In "Integrations": under "GitHub Integration" click Update GitHub settings to pull the latest configuration from master
In "Changes": click Queue plan if one has not already been queued, then Confirm & Apply to provision the aws-us-east-1-prod environment
Note: You'll likely see an error related to the OpenVPN AMI during the apply, you'll need to follow the link to the AWS Marketplace provided and complete the steps to opt-in to the OpenVPN AMI for the apply to complete successfully
On a successful apply, there will be instructions output in a green font that will tell you how to interact with your new infrastructure
This same process can be repeated for the aws-us-east-1-staging environment as well as any other regions you would like to deploy infrastructure into. If you are deploying into a new region, be sure you have Artifacts created for it by following the Multi-Region steps below.
Setup Vault
A HA Vault should have already been provisioned, but you'll need to initialize and unseal Vault to make it work. To do so, SSH into each of the newly provisioned Vault instances and follow the below instructions. The output from your apply in Atlas will tell you how to SSH into Vault.
Initialize Vault
$ vault init | tee /tmp/vault.init > /dev/null
Retrieve the unseal keys and root token from /tmp/vault.init and store these in a safe place
Shred keys and token once they are stored in a safe place
$ shred /tmp/vault.init
Use the unseal keys you just retrieved to unseal Vault
Authenticate with Vault by entering your root token retrieved earlier
$ vault auth
Shred the token
$ shred -u -z ~/.vault-token
After Vault is initialized and unsealed, update the below variable(s) and apply the changes. Next time you deploy your application, you should see the Vault/Consul Template integration working in your Node.js website!
In "Variables" of the aws-us-east-1-prod environment: Update vault_token with the root-token
Commit a new change (git commit --allow-empty -m "Force a change in Atlas") to your demo-app-nodejs repo, this should trigger a new "plan" in aws-us-east-1-prod after a new artifact is built
In "Changes" of the the aws-us-east-1-prod environment: Queue a new plan and apply the changes to deploy the new application to see the Vault/Consul Template integration at work
You'll eventually want to configure Vault specific to your needs and setup appropriate ACLs.
Multi-Region
If you'd like to expand outside of us-east-1, there are a few changes you need to make. We'll use the region us-west-2 as an example of how to do this.
Add a new variable for the new region's AMI and a new variable for the new Build name. Note that the AMI will need to be from the region you intend to use.
Once the updates to base.json have been completed and pushed to master (this should trigger a new Build Configuration to be sent to Atlas), complete the Child Artifact steps with the new region instead of us-east-1 to build new artifacts in that region.
There is currently an issue when destroying the aws_internet_gateway resource that requires you to run terraform destroy a second time as it fails the first.
Note:terraform destroy deletes real resources, it is important that you take extra precaution when using this command. Verify that you are in the correct environment, verify that you are using the correct keys, and set any extra configuration necessary to prevent someone from accidentally destroying infrastructure.
The text was updated successfully, but these errors were encountered:
Sign up for freeto subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Setup
Take all instructions from Setup forward and paste into a new "Issue" on your repository, this will allow you to check items off the list as they're completed and track your progress.
FullAccess
to EC2, S3, Route53, and IAM in order for Terraform to create all of the resourcesNote: Terraform creates real resources in AWS that cost money. Don't forget to destroy your PoC environment when finished to avoid unnecessary expenses.
Set Local Environment Variables
Set the below environment variables if you'll be using Packer or Terraform locally.
Generate Keys and Certs
There are certain resources in this project that require the use of keys and certs to validate identity, such as Terraform's
remote-exec
provisioners and TLS in Consul/Vault. For the sake of quicker & easier onboarding, we've created a gen_key.sh and gen_cert.sh script that can generate these for you.Note: While using this for PoC purposes, these keys and certs should suffice. However, as you start to move your actual applications into this infrastructure, you'll likely want to replace these self-signed certs with certs that are signed by a CA and use keys that are created with your security principles in mind.
site
keyssh gen_key.sh site
in setup.pub
) key from the existing private (.pem
) key specified (e.g.sh gen_key.sh site ~/.ssh/my-existing-private-key.pem
).pub
) and private (.pem
) key in the setup/. directorysite
andvault
certssh gen_cert.sh YOUR_DOMAIN YOUR_COMPANY
in setup (e.g.sh gen_cert.sh hashicorpdemo.com HashiCorp
)site
(external self-signed cert for browsers) and one namedvault
(internal self-signed cert for Consul/Vault TLS), both within the setup/. directoryCreate and Configure Artifacts
Use the New Build Configuration tool to create each new Build Configuration below. Enter the names provided as you go through the checklist and be sure to leave the Automatically build on version uploads and Connect build configuration to a GitHub repository boxes unchecked for each.
After creating each Build Configuration, there is some additional configuration you'll need to do. The summary of what will need to be completed for each Build Configuration is below, the relevant values are provided as you go through the checklist.
Add Environment Variables
ATLAS_USERNAME
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_DEFAULT_REGION
:us-east-1
Integrate with GitHub
best-practices
GitHub repository you just forkedpacker
for Packer DirectoryQueue Build
You can then go to "Builds" in the left navigation of each of the Build Configuration(s) and click Queue build, this should create new artifact(s). You'll need to wait for the
base
artifact to be created before you queue any of the child builds as we take advantage of Base Artifact Variable Injection.You do NOT want to queue builds for
aws-us-east-1-ubuntu-nodejs
because this Build Template will be used by the application. Queueing a build foraws-us-east-1-ubuntu-nodejs
will fail with the error* Bad source 'app/': stat app/: no such file or directory
.Base Artifact
aws-us-east-1-ubuntu-base
Artifactaws-us-east-1-ubuntu-base
aws-us-east-1-ubuntu-base
best-practices
repopacker
aws/ubuntu/base.json
base
artifactChild Artifacts
Wait until the Base Artifact has been created before moving on to the child Build Configurations. These will fail with an error of
* A source_ami must be specified
until the Base Artifact has been created and selected.For child Build Configurations, there is one additional step you need to take. In "Settings", set Inject artifact ID during build to
aws-us-east-1-ubuntu-base
for each.aws-us-east-1-ubuntu-consul
Artifactaws-us-east-1-ubuntu-consul
aws-us-east-1-ubuntu-consul
aws-us-east-1-ubuntu-base
best-practices
repopacker
aws/ubuntu/consul.json
aws-us-east-1-ubuntu-vault
Artifactaws-us-east-1-ubuntu-vault
aws-us-east-1-ubuntu-vault
aws-us-east-1-ubuntu-base
best-practices
repopacker
aws/ubuntu/vault.json
aws-us-east-1-ubuntu-haproxy
Artifactaws-us-east-1-ubuntu-haproxy
aws-us-east-1-ubuntu-haproxy
aws-us-east-1-ubuntu-base
best-practices
repopacker
aws/ubuntu/haproxy.json
aws-us-east-1-ubuntu-nodejs
Build Configurationaws-us-east-1-ubuntu-nodejs
aws-us-east-1-ubuntu-nodejs
aws-us-east-1-ubuntu-base
best-practices
repopacker
aws/ubuntu/nodejs.json
aws-us-east-1-ubuntu-nodejs
)aws-us-east-1-ubuntu-consul
aws-us-east-1-ubuntu-vault
aws-us-east-1-ubuntu-haproxy
We built artifacts for the
us-east-1
region in this walkthrough. If you'd like to add another region, follow the Multi-Region setup instructions below.If you decide to update any of the artifact names, be sure those name changes are reflected in your
terraform.tfvars
file(s).Deploy a
us-east-1
Node.js Applicationdemo-app-nodejs
repoaws-us-east-1-nodejs
aws-us-east-1-ubuntu-nodejs
demo-app-nodejs
Upload new versions of the application by merging a commit into master from your forked repo. This will upload your latest app code and trigger a Packer build to create a new compiled application artifact.
If you don't have a change to make, you can force an application ingress into Atlas with an empty commit.
If you want to create artifacts in other regions, complete these same steps but select a Build Template from the region you'd like.
Provision the
aws-global
Environmentaws-global
Environment from GitHubYOUR_ATLAS_ORG/aws-global
YOUR_GITHUB_USERNAME/best-practices
terraform
terraform push
your environment to Atlas to set the Terraform variables, the GitHub Ingress does not currently pull in variablesglobal
folder:cd terraform/providers/aws/global/.
terraform remote config -backend-config name=$ATLAS_USERNAME/aws-global
terraform get
terraform push -name $ATLAS_USERNAME/aws-global -var "atlas_token=$ATLAS_TOKEN" -var "atlas_username=$ATLAS_USERNAME"
aws-global
environmentATLAS_USERNAME
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_DEFAULT_REGION
:us-east-1
TF_ATLAS_DIR
:providers/aws/global
TF_ATLAS_DIR
variable to identify where it should run Terraform commands within the repoREPLACE_IN_ATLAS
domain
with your domain (e.g.hashicorpdemo.com
)atlas_username
with your Atlas usernameiam_admins
with a comma separated list of users you'd like added to theadmin
group in IAM (e.g.cameron,jay,jon,kevin
)global-admin
aws-global
environmentProvision the
aws-us-east-1-prod
Environmentaws-us-east-1-prod
Environment from GitHubYOUR_ATLAS_ORG/aws-us-east-1-prod
YOUR_GITHUB_USERNAME/best-practices
terraform
terraform push
your environment to Atlas to set the Terraform variables, the GitHub Ingress does not currently pull in variablesaws_us_east_1_prod
folder:cd terraform/providers/aws/aws_us_east_1_prod/.
terraform remote config -backend-config name=$ATLAS_USERNAME/aws-us-east-1-prod
terraform get
terraform push -name $ATLAS_USERNAME/aws-us-east-1-prod -var "atlas_token=$ATLAS_TOKEN" -var "atlas_username=$ATLAS_USERNAME"
aws-us-east-1-prod
environmentATLAS_USERNAME
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_DEFAULT_REGION
:us-east-1
TF_ATLAS_DIR
:providers/aws/us_east_1_prod
TF_ATLAS_DIR
variable to identify where it should run Terraform commands within the repoREPLACE_IN_ATLAS
, you will use the contents of the keys and certs created in Generate Keys and Certs as values for most of these variablesatlas_token
with your Atlas tokenatlas_username
with your Atlas usernamesite_public_key
with the contents ofsite.pub
site_private_key
with the contents ofsite.pem
site_ssl_cert
with the contents ofsite.crt
site_ssl_key
with the contents ofsite.key
vault_ssl_cert
with the contents ofvault.crt
vault_ssl_key
with the contents ofvault.key
aws-us-east-1-prod
environmentThis same process can be repeated for the
aws-us-east-1-staging
environment as well as any other regions you would like to deploy infrastructure into. If you are deploying into a new region, be sure you have Artifacts created for it by following the Multi-Region steps below.Setup Vault
A HA Vault should have already been provisioned, but you'll need to initialize and unseal Vault to make it work. To do so, SSH into each of the newly provisioned Vault instances and follow the below instructions. The output from your apply in Atlas will tell you how to SSH into Vault.
Initialize Vault
$ vault init | tee /tmp/vault.init > /dev/null
Retrieve the unseal keys and root token from
/tmp/vault.init
and store these in a safe placeShred keys and token once they are stored in a safe place
$ shred /tmp/vault.init
Use the unseal keys you just retrieved to unseal Vault
Authenticate with Vault by entering your root token retrieved earlier
$ vault auth
Shred the token
$ shred -u -z ~/.vault-token
After Vault is initialized and unsealed, update the below variable(s) and apply the changes. Next time you deploy your application, you should see the Vault/Consul Template integration working in your Node.js website!
aws-us-east-1-prod
environment: Updatevault_token
with theroot-token
git commit --allow-empty -m "Force a change in Atlas"
) to yourdemo-app-nodejs
repo, this should trigger a new "plan" inaws-us-east-1-prod
after a new artifact is builtaws-us-east-1-prod
environment: Queue a new plan and apply the changes to deploy the new application to see the Vault/Consul Template integration at workYou'll eventually want to configure Vault specific to your needs and setup appropriate ACLs.
Multi-Region
If you'd like to expand outside of
us-east-1
, there are a few changes you need to make. We'll use the regionus-west-2
as an example of how to do this.In the base.json Packer template...
Add a new variable for the new region's AMI and a new variable for the new Build name. Note that the AMI will need to be from the region you intend to use.
Add an additional builder for the new region
Add an additional post-processor for the new region
Once the updates to base.json have been completed and pushed to
master
(this should trigger a new Build Configuration to be sent to Atlas), complete the Child Artifact steps with the new region instead ofus-east-1
to build new artifacts in that region.To deploy these new artifacts...
us_west_2_prod
andus_west_2_prod
In each of the new "us_west_2"
terraform.tfvars
files...us-east-1
withus-west-2
.ami-5fe36434
toami-9fe2f2af
azs
variable depending on what the subnets in that region supportFinally, push these new environments to
master
and follow the same steps you completed to deploy your environments inus-east-1
.Terraform Destroy
If you want to destroy the environment, run the following command in the appropriate environment's directory
There is currently an issue when destroying the
aws_internet_gateway
resource that requires you to runterraform destroy
a second time as it fails the first.Note:
terraform destroy
deletes real resources, it is important that you take extra precaution when using this command. Verify that you are in the correct environment, verify that you are using the correct keys, and set any extra configuration necessary to prevent someone from accidentally destroying infrastructure.The text was updated successfully, but these errors were encountered: