Introduction to Automated Zero Downtime Deployment
data:image/s3,"s3://crabby-images/f56f5/f56f5f4568bf3cd5f55e3605768c034eea2e3a81" alt=""
data:image/s3,"s3://crabby-images/eb44f/eb44f55a459630e2a7f7769bb00b22a625254031" alt=""
data:image/s3,"s3://crabby-images/b5d26/b5d26ee1568a7b7a0992c2fb07ff8398980aabae" alt=""
Github
Codepipeline
ECS
data:image/s3,"s3://crabby-images/47a40/47a407a97f0b48d1f2c28d2c0605e6f6b05b32bf" alt=""
data:image/s3,"s3://crabby-images/48eab/48eab0a7a5df5e2dd17ecbc9c2cde82dcd1912e1" alt=""
$whoami
-
Asjad Saboor
-
Technical Lead @ 10Pearls
-
Full Stack JS Developer
data:image/s3,"s3://crabby-images/b30a5/b30a5248f03b091d46c5f72341d307ba86f1a7f0" alt=""
data:image/s3,"s3://crabby-images/7c731/7c731ea1b56973270ae1d0025bd194f1698f29f4" alt=""
data:image/s3,"s3://crabby-images/26dfd/26dfd20b492484662595e1cd8ad71c732872d731" alt=""
data:image/s3,"s3://crabby-images/aa353/aa353772dc25fa346890dc9d0d61dbf4dc3ff2dd" alt=""
data:image/s3,"s3://crabby-images/48eab/48eab0a7a5df5e2dd17ecbc9c2cde82dcd1912e1" alt=""
Agenda
- What is Container orchestration?
- What is AWS ECS?
- Explore some basic AWS services
- Overview of Infrastructure diagram
- Deploy NodeJS API using ECS
- Automate deployment process using Codepipeline
data:image/s3,"s3://crabby-images/48eab/48eab0a7a5df5e2dd17ecbc9c2cde82dcd1912e1" alt=""
Container Orchestration
data:image/s3,"s3://crabby-images/9df8c/9df8c09fe5b8ae72cd48d953551223dc55029d23" alt=""
Container Orchestration
-
Automation of all aspects of coordinating and managing containers which includes
- Configuring and scheduling of containers
- Provisioning and deployments of containers
- Availability of containers
- Scaling of containers to equally balance application workloads across infrastructure
- Allocation of resources between containers
- load balancing, traffic routing and service discovery of containers
- Health monitoring of containers
- Securing the interactions between containers.
data:image/s3,"s3://crabby-images/c1a6e/c1a6eaa6698c8a42aa35f633a498b306d63fb48f" alt=""
Container Orchestration Tools
data:image/s3,"s3://crabby-images/b6ade/b6adebd6a2795af6029757507f3585923489f51d" alt=""
data:image/s3,"s3://crabby-images/f84b0/f84b0735b23fad21f10679302887a1ca48c026bd" alt=""
data:image/s3,"s3://crabby-images/69341/693418001a49cfad77c51153abb7f5462f0d16e5" alt=""
data:image/s3,"s3://crabby-images/b9d7e/b9d7e18f180467b39a70ab45c27671f5a68c4a5d" alt=""
data:image/s3,"s3://crabby-images/2fbc3/2fbc3b877d233cc4e6952cafa8065014e702a809" alt=""
data:image/s3,"s3://crabby-images/fcb06/fcb063889db067e90d96e1b22424993a1ef6468c" alt=""
What is ECS?
- Elastic Container Service
- Highly scalable, high-performance container orchestration service
- Let you host your services in serverless infrastructure
- Fargate - Containers without servers
-
Has three main components:
- Elastic Container Registry
- Clusters
- Task Definitions
data:image/s3,"s3://crabby-images/b6ade/b6adebd6a2795af6029757507f3585923489f51d" alt=""
data:image/s3,"s3://crabby-images/5d11b/5d11b2dcde266109fcd5ed5ba2512828a6dedca8" alt=""
data:image/s3,"s3://crabby-images/3d6a9/3d6a9a85fa0df4b6d2e8a0b390062be7dee050b5" alt=""
Some more AWS services
- Amazon Relational Database Service (RDS)
- Security Groups
- Codepipeline
- VPC
- Cloud Watch for logging
- Load balancer
What is Codepipeline?
- A continuous delivery service to model, visualize, and automate the steps required to release your software.
- Supports zero downtime deployment.
data:image/s3,"s3://crabby-images/33a30/33a301585884df318a89fe2cba21722df05e904c" alt=""
Infrastructure Diagram
data:image/s3,"s3://crabby-images/3e415/3e415d38efcd5fc45dfa97cadaeffd97d2980ba4" alt=""
Let's begin deployment....
Questions?
Thank you
Feedback
https://bit.ly/2Zhn5m0
NodeJS Training - ECS
By Asjad Saboor
NodeJS Training - ECS
- 412