AWS Deployment Tools: Choosing the Right Application Service

The right application deployment tools can make the process more effective. But choosing can be a challenge.

It’s no secret that coding and deploying complex web applications is a tricky business. Visualizing the most efficient process and structural design needed to get your product out the door can be the toughest task of all. So choosing the right tools to help you along is critical. But which tools to choose is often by no means obvious.

AWS offers three distinct services aimed at simplifying and automating project deployment and management: Elastic Beanstalk, CloudFormation, and OpsWorks. Why three deployment tools? Because each service offers its own unique features and workflow style that’s ideal for different sets of contexts.

Since I’ve personally always found distinguishing between the use-cases of each of these services a little intimidating, I’ll share what I’ve learned over time (AWS has a FAQ offering an overview of their set of deployment tools from an OpsWorks perspective). Hopefully, you’ll add your own hard-earned observations in the comments.

Deployment tools: Elastic Beanstalk

Elastic Beanstalk is probably the easiest of the three to describe. For all intents and purposes, all you need to do is provide your application code created in one of a dozen or so platforms (Ruby, PHP, Node.js, Docker, etc.) and Beanstalk will pretty much invisibly build the necessary AWS infrastructure around it. You don’t need to get your hands dirty in administration but, to allow all that to happen, you give up some flexibility and control.

Ideal customer: development teams that don’t want to know about anything that even smells like IP addressing schemes.
Greatest strength: simplicity.

Deployment tools: CloudFormation

CloudFormation is all about JSON formatted templates. AWS describes it as a “building block service that enables customers to provision and manages almost any AWS resource.”

You have to choose your environment tier (web app or worker) and the AWS resources your application will use (EC2 instance and EBS volume types, RDS engine, etc), so you’ll definitely have more configuration work up front. But the payoff comes in the power of fully scripted deployments and, (as I’ve seen it described) an effectively automatically documented infrastructure. CloudFormation also allows you to directly integrate Git repos into your workflow.

Ideal customer: people with projects for which the ability to reliably and predictably reproduce an environment is important.
Greatest strength: scripting (templates).

Deployment tools: OpsWorks

Conceptually, OpsWorks is probably the hardest of these three services to properly digest. It’s built on a framework of stacks and layers. The project, at the top level, is defined by its stack which, in turn, is made up of layers. Each layer is essentially one or more EC2 instances running a pre-defined service like, for instance, a PHP/Apache web server. OpsWorks built-in layers, which on their own are somewhat narrow in scope, can be customized using chef recipes…but that could add a significant learning curve to the mix. I think it’s fair to characterize OpsWorks as the most hands-on of AWS’s three deployment services, and therefore the most complex.

Ideal customer: developers who need to quickly model application configurations. Being able to easily swap layers in and out can speed up and improve that process.
Greatest strength: a balance of the simplicity of Elastic Beanstalk and the flexibility of CloudFormation (if that description is helpful).

Avatar

Written by

David Clinton

A Linux system administrator with twenty years' experience as a high school teacher, David has been around the industry long enough to have witnessed decades of technology trend predictions; most of them turning out to be dead wrong.

Related Posts

Avatar
Michael Sheehy
— August 19, 2019

What Exactly Is a Cloud Architect and How Do You Become One?

One of the buzzwords surrounding the cloud that I'm sure you've heard is "Cloud Architect." In this article, I will outline my understanding of what a cloud architect does and I'll analyze the skills and certifications necessary to become one. I will also list some of the types of jobs ...

Read more
  • AWS
  • Cloud Computing
Avatar
Andrew Larkin
— August 13, 2019

Content Roadmap: AZ-500, ITIL 4, MS-100, Google Cloud Associate Engineer, and More

Last month, Cloud Academy joined forces with QA, the UK’s largest B2B skills provider, and it put us in an excellent position to solve a massive skills gap problem. As a result of this collaboration, you will see our training library grow with additions from QA’s massive catalog of 500+...

Read more
  • AWS
  • Azure
  • content roadmap
  • Google Cloud Platform
Avatar
Adam Hawkins
— August 9, 2019

DevSecOps: How to Secure DevOps Environments

Security has been a friction point when discussing DevOps. This stems from the assumption that DevOps teams move too fast to handle security concerns. This makes sense if Information Security (InfoSec) is separate from the DevOps value stream, or if development velocity exceeds the band...

Read more
  • AWS
  • cloud security
  • DevOps
  • DevSecOps
  • Security
Avatar
Stefano Giacone
— August 8, 2019

Test Your Cloud Knowledge on AWS, Azure, or Google Cloud Platform

Cloud skills are in demand | In today's digital era, employers are constantly seeking skilled professionals with working knowledge of AWS, Azure, and Google Cloud Platform. According to the 2019 Trends in Cloud Transformation report by 451 Research: Business and IT transformations re...

Read more
  • AWS
  • Cloud skills
  • Google Cloud
  • Microsoft Azure
Avatar
Andrew Larkin
— August 7, 2019

Disadvantages of Cloud Computing

If you want to deliver digital services of any kind, you’ll need to estimate all types of resources, not the least of which are CPU, memory, storage, and network connectivity. Which resources you choose for your delivery —  cloud-based or local — is up to you. But you’ll definitely want...

Read more
  • AWS
  • Azure
  • Cloud Computing
  • Google Cloud Platform
Joe Nemer
Joe Nemer
— August 6, 2019

Google Cloud vs AWS: A Comparison (or can they be compared?)

The "Google Cloud vs AWS" argument used to be a common discussion among our members, but is this still really a thing? You may already know that there are three major players in the public cloud platforms arena: Amazon Web Services (AWS), Microsoft Azure, and Google Cloud Platform (GCP)...

Read more
  • AWS
  • Google Cloud Platform
  • Kubernetes
Avatar
Stuart Scott
— July 29, 2019

Deployment Orchestration with AWS Elastic Beanstalk

If you're responsible for the development and deployment of web applications within your AWS environment for your organization, then it's likely you've heard of AWS Elastic Beanstalk. If you are new to this service, or simply need to know a bit more about the service and the benefits th...

Read more
  • AWS
  • elastic beanstalk
Avatar
Stuart Scott
— July 26, 2019

How to Use & Install the AWS CLI

What is the AWS CLI? | The AWS Command Line Interface (CLI) is for managing your AWS services from a terminal session on your own client, allowing you to control and configure multiple AWS services and implement a level of automation. If you’ve been using AWS for some time and feel...

Read more
  • AWS
  • AWS CLI
  • Command line interface
Alisha Reyes
Alisha Reyes
— July 22, 2019

Cloud Academy’s Blog Digest: July 2019

July has been a very exciting month for us at Cloud Academy. On July 10, we officially joined forces with QA, the UK’s largest B2B skills provider (read the announcement). Over the coming weeks, you will see additions from QA’s massive catalog of 500+ certification courses and 1500+ ins...

Read more
  • AWS
  • Azure
  • Cloud Academy
  • Cybersecurity
  • DevOps
  • Kubernetes
Avatar
Stuart Scott
— July 18, 2019

AWS Fundamentals: Understanding Compute, Storage, Database, Networking & Security

If you are just starting out on your journey toward mastering AWS cloud computing, then your first stop should be to understand the AWS fundamentals. This will enable you to get a solid foundation to then expand your knowledge across the entire AWS service catalog.   It can be both d...

Read more
  • AWS
  • Compute
  • Database
  • fundamentals
  • networking
  • Security
  • Storage
Avatar
Adam Hawkins
— July 17, 2019

How to Become a DevOps Engineer

The DevOps Handbook introduces DevOps as a framework for improving the process for converting a business hypothesis into a technology-enabled service that delivers value to the customer. This process is called the value stream. Accelerate finds that applying DevOps principles of flow, f...

Read more
  • AWS
  • AWS Certifications
  • DevOps
  • DevOps Foundation Certification
  • Engineer
  • Kubernetes
Avatar
Vineet Badola
— July 15, 2019

AWS AMI Virtualization Types: HVM vs PV (Paravirtual VS Hardware VM)

Amazon Machine Images (AWS AMI) offers two types of virtualization: Paravirtual (PV) and Hardware Virtual Machine (HVM). Each solution offers its own advantages. When we’re using AWS, it’s easy for someone — almost without thinking —  to choose which AMI flavor seems best when spinning...

Read more
  • AWS
  • Hardware Virtual Machine
  • Paravirtual
  • Virtualization