Skip to content

Latest commit

 

History

History
 
 

metamon

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

Metamon

This repository and walkthrough guides you through deploying Metamon on AWS using Atlas.

General setup

  1. Download and install Virtualbox, Vagrant, Packer, and Terraform.
  2. Clone this repository.
  3. Create an Atlas account and save your Atlas username as an environment variable in your .bashrc file. export ATLAS_USERNAME=<your_atlas_username>
  4. Generate an Atlas token and save as an environment variable in your .bashrc file. export ATLAS_TOKEN=<your_atlas_token>
  5. Get your AWS access and secret keys and save as environment variables in your .bashrc file. export AWS_ACCESS_KEY=<your_aws_access_key> export AWS_SECRET_KEY=<your_aws_secret_key>
  6. In the Vagrantfile and Packer files ops/metamon.json and ops/consul.json you must replace YOUR_ATLAS_USERNAME with your Atlas username.
  7. When running terraform you can should either pass variables on the command line as noted in ops/terraform/terraform.tfvars.tf, or set the following environment variables ATLAS_USERNAME, ATLAS_TOKEN, AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY, and AWS_DEFAULT_REGION with your Atlas username, Atlas token, AWS Access Key Id, AWS Secret Access key, and default region (us-east-1 in our examples).
  8. Generate the keys in ops/terraform/ssh_keys. You can simply run sh scripts/generate_key_pair.sh from the ops/terraform directory and it will generate new keys for you. If you have an existing private key you would like to use, pass in the private key file path as the first argument of the shell script and it will use your key rather than generating a new one (e.g. sh scripts/generate_key_pair.sh ~/.ssh/my-private-key.pem). If you don't run the script, you will likely see the error Error import KeyPair: The request must contain the parameter PublicKeyMaterial on a terraform apply or terraform push.
  9. Make sure your VPC is setup correctly. If you have an AWS classic account or having an existing VPC setup, there are some steps you'll want to follow to make sure it is setup to allow Packer to work.

Introduction and Configuring Metamon

Before jumping into configuration steps, it's helpful to have a mental model for how the Atlas workflow fits in.

Metamon's motivation is to make it dead simple to setup a standardized, automated, and generic environment using Ansible playbooks. Metamon will provision a Vagrant box to be a development ready web app using Django, Gunicorn, Nginx, and PostgreSQL. Take a look at the Metamon repository for more context on how the provisioning works.

The files in this repository are designed to make it just as simple to move from development to production by safely deploying and managing your infrastructure on AWS using the Atlas workflow. If you haven't deployed an app with Atlas before, we recommend you start with the introductory tutorial. Atlas by HashiCorp is a platform to develop, deploy, and maintain applications on any infrastructure provider.

Step 1: Build a Consul Server AMI with Packer

  1. Navigate to the ops/packer directory on the command line.
  2. For Consul to work with this setup, we first need to create a Consul server AMI that will be used to build our Consul cluster. To do this, run packer push consul.json in the ops/packer directory. This will send the build configuration to Atlas so it can build your Consul server AMI remotely.
  3. View the status of your build by going to the Builds tab of your Atlas account and clicking on the "consul" build configuration. You will notice that the "consul" build errored immediately with the following error Build 'amazon-ebs' errored: No valid AWS authentication found. This is because we need to add our AWS_ACCESS_KEY and AWS_SECRET_KEY environment variables to the build configuration. Consul Build Configuration - Variables Error
  4. Navigate to "Variables" on the left side panel of the "consul" build configuration, then add the key AWS_ACCESS_KEY using your "AWS Access Key Id" as the value and the key AWS_SECRET_KEY using your "AWS Secret Access Key" as the value. Consul Build Configuration - Variables
  5. Navigate back to "Builds" on the left side panel of the "consul" build configuration, then click "Rebuild" on the "consul" build configuration that errored. This one should succeed. Consul Build Configuration - Success
  6. This creates a fully-baked Consul server AMI that will be used for your Consul cluster.

Step 2: Build a Metamon AMI with Packer

  1. Navigate to the ops/packer directory on the command line.
  2. Build an AMI using Metamon's Ansible provisioning that will create a functioning web app that uses Django, Gunicorn, Nginx, PostgreSQL and a few other Metamon features. To do this, run packer push metamon.json in the ops/packer directory. This will send the build configuration to Atlas so it can build your Metamon AMI remotely.
  3. View the status of your build by going to the Builds tab of your Atlas account and clicking on the "metamon" build configuration. You will notice that the "metamon" build configuration errored immediately with the following error * Bad source '/packer/app': stat /packer/app: no such file or directory. This is because there is a provisioner in the ops/metamon.json Packer template that is expecting the application to already be linked. If you take that provisioner out, it would work, but you're just going to need it back in there after you link your application in the next step. This error is fine for now, we will be fixing this shortly. Metamon Build Configuration - Application Error
  4. We also need to add our environment variables for the "metamon" build configuration so we don't get the same error we got with the "consul" build configuration. Navigate to "Variables" on the left side panel of the "metamon" build configuration, then add the key AWS_ACCESS_KEY using your "AWS Access Key Id" as the value and the key AWS_SECRET_KEY using your "AWS Secret Access Key" as the value. Metamon Build Configuration - Variables

Step 3: Link your Application Code in Atlas

  1. Navigate to the root directory of your project where the Vagrant file is directory on the command line.
  2. You'll now want to link up your actual Metamon application code to Atlas so that when you make any code changes, you can vagrant push them to Atlas and it will rebuild your AMI automatically. To do this, simply run vagrant push in the root directory of your project.
  3. This will send your application code to Atlas, which is everything in the app directory. Link the "metamon" application and build configuration by clicking "Links" on the left side panel of the "metamon" build configuration in the Builds tab of your Atlas account. Complete the form with your Atlas username, metamon as the application name, and /app as the destination path. Metamon Build Configuration - Links
  4. Now that your "metamon" application and build configuration are linked, navigate back to "Builds" on the left side panel of the "metamon" build configuration, then click "Rebuild" on the "metamon" build configuration that errored. This one should succeed. Metamon Build Configuration - Success
  5. This creates a fully-baked Django web app AMI that uses Consul for service discovery/configuration and health checking.

** packer push metamon.json will rebuild the AMI with the application code that was last pushed to Atlas whereas vagrant push will push your latest application code to Atlas and THEN rebuild the AMI. When you want any new modifications of your application code to be included in the AMI, do a vagrant push, otherwise if you're just updating the packer template and no application code has changed, do a packer push metamon.json.

Step 4: Deploy Metamon Web App and Consul Cluster with Terraform

  1. Wait for both the “consul” and “metamon” builds to complete without errors
  2. Navigate to the ops/terraform directory on the command line.
  3. Run terraform remote config -backend-config name=<your_atlas_username>/metamon in the ops/terraform directory, replacing <your_atlas_username> with your Atlas username to configure remote state storage for this infrastructure. Now when you run Terraform, the infrastructure state will be saved in Atlas, keeping a versioned history of your infrastructure.
  4. Get the latest modules by running terraform get in the ops/terraform directory.
  5. Run terraform push -name <your_atlas_username>/metamon in the ops/terraform directory, replacing <your_atlas_username> with your Atlas username. Make sure that your files are checked into version control or add the switch -vcs=false to the terraform push command.
  6. Go to the Environments tab in your Atlas account and click on the "metamon" environment. Navigate to "Changes" on the left side panel of the environment, click on the latest "Run" and wait for the "plan" to finish, then click "Confirm & Apply" to deploy your Metamon web app and Consul cluster. Confirm & Apply
  7. You should see 4 new boxes spinning up in EC2, one named "metamon_1", which is your web app, and three named "consul_n", which are the nodes in your Consul cluster. AWS - Success
  8. That's it! You just deployed a a Metamon web app and Consul cluster. In "Changes" you can view all of your configuration and state changes, as well as deployments. If you navigate back to "Status" on the left side panel, you will see the real-time health of all your nodes and services. Infrastructure Status

Final Step: Verify it Worked!

  1. Once the "metamon_1" box is running, go to its public ip and you should see a website that reads "Hello, Atlas!" Hello, Atlas!
  2. Change your app code by modifying app/app/views.py to say "Hello, World!" instead of "Hello, Atlas!".
  3. Run vagrant push in your projects root directory (where the Vagrantfile is). Once the packer build finishes creating the new AMI (view this in Builds tab of your Atlas account), run terraform push -name <your_atlas_username>/metamon in the ops/terraform directory.
  4. Go to the Environments tab in your Atlas account and click on the "metamon" environment. Navigate to "Changes" on the left side panel of the environment, click on the latest "Run" and wait for the "plan" to finish, then click "Confirm & Apply" to deploy your updated Metamon web app! Go to the new "metamon_1" box's public ip and it should now say "Hello, World!".

** One thing to note... Because your Django web app and PostgreSQL are running on the same box, anytime you rebuild that AMI and deploy, it's going to destroy the instance and create a new one - effectively destroying all of your data.

Cleanup

  1. Run terraform destroy to tear down any infrastructure you created. If you want to bring it back up, simply run terraform push -name <your_atlas_username>/metamon and it will bring your infrastructure back to the state it was last at.