Coder Social home page Coder Social logo

deploy-web-app-cloudformation's Introduction

Deploy a High-Availability Web App using CloudFormation

Part of Udacity's DevOps ND: Creating this project will give you the hands-on experience you need to confidently talk about infrastructure as code. We have chosen a realistic scenario where you will deploy a dummy application (a sample JavaScript or HTML file) to the Apache Web Server running on an EC2 instance.


Overview:

Your company is creating an Instagram clone called Udagram.

Developers want to deploy a new application to the AWS infrastructure.

You have been tasked with provisioning the required infrastructure and deploying a dummy application, along with the necessary supporting software.

This needs to be automated so that the infrastructure can be discarded as soon as the testing team finishes their tests and gathers their results.

Architecture Diagram:


Architecture Diagram
Architecture Diagram

View on Lucidchart

Specifications:

  • You'll need to create a Launch Configuration for your application servers in order to deploy four servers, two located in each of your private subnets. The launch configuration will be used by an auto-scaling group.
  • You'll need two vCPUs and at least 4GB of RAM. The Operating System to be used is Ubuntu 18. So, choose an Instance size and Machine Image (AMI) that best fits this spec.
  • Be sure to allocate at least 10GB of disk space so that you don't run into issues. Security Groups and Roles
  • Since you will be downloading the application archive from an S3 Bucket, you'll need to create an IAM Role that allows your instances to use the S3 Service. Udagram communicates on the default HTTP Port: 80, so your servers will need this inbound port open since you will use it with the Load Balancer and the Load Balancer Health Check. As for outbound, the servers will need unrestricted internet access to be able to download and update their software.
  • The load balancer should allow all public traffic (0.0.0.0/0) on port 80 inbound, which is the default HTTP port. Outbound, it will only be using port 80 to reach the internal servers. -The application needs to be deployed into private subnets with a Load Balancer located in a public subnet. One of the output exports of the CloudFormation script should be the public URL of the LoadBalancer. Bonus points if you add http:// in front of the load balancer DNS Name in the output, for convenience.

Usage:

  • Clone the repository:

    $ git clone https://github.com/kfrawee/deploy-web-app-cloudformation.git
  • Navigate to the directory:

    $ cd .\deploy-web-app-cloudformation\

This project uses AWS CLI. So, make sure you get that first and give the necessary permissions to aws cli. Follow this page for getting started.

  1. Store stack names variables:
$ export networks_stack_name="networks"
$ export servers_stack_name="servers"
  1. Create networks stack:
$ sh create.sh $networks_stack_name templates/udacity_project_networks.yml templates/udacity_project_nerworks_params.json
Creating stack: networks
{
    "StackId": "arn:aws:cloudformation:us-east-1:452206074273:stack/networks/6e659830-8d2d-11ed-8f30-0e0c198b19b3"
}
  1. Create servers stack:
$ sh create.sh $servers_stack_name templates/udacity_project_servers.yml templates/udacity_project_servers_params.json
Creating stack: servers
{
    "StackId": "arn:aws:cloudformation:us-east-1:452206074273:stack/servers/2d5623c0-8d30-11ed-a8e2-0eaa196a18d1"
}

Cleaning:

$ sh delete.sh $servers_stack_name 
Deleting stack: servers
$ sh delete.sh $networks_stack_name 
Deleting stack: networks

deploy-web-app-cloudformation's People

Contributors

kfrawee avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.