Distributed Node #12
EKS
data:image/s3,"s3://crabby-images/b6f2b/b6f2b5f2449a3e1d6ca5160b11de51e2c5f26a0d" alt=""
And take your prize!
Join https://kahoot.it
data:image/s3,"s3://crabby-images/21fe6/21fe6016e9c35471edc45634f7d6d72923cb283c" alt=""
data:image/s3,"s3://crabby-images/3d21a/3d21af4dd971607f19af964f278512cba55e46f7" alt=""
data:image/s3,"s3://crabby-images/b807b/b807b320c29fcfbe544787d9baa905fa4e9d263b" alt=""
data:image/s3,"s3://crabby-images/434ab/434ab1710e604903fcd181a10e3a77be53776734" alt=""
Amazon Elastic Kubernetes Service (Amazon EKS) - a managed service that you can use to run Kubernetes on AWS without needing to install, operate, and maintain your own Kubernetes control plane or nodes.
data:image/s3,"s3://crabby-images/d16ba/d16baf14b60b3d855d8e6bc2eebb15ea412e9cd0" alt=""
data:image/s3,"s3://crabby-images/560cf/560cfcbdb7abddb3767ca256af032b1fa049fa7b" alt=""
AWS EKS Setup
Amazon Virtual Private Cloud (Amazon VPC) is a service that lets you launch AWS resources in a logically isolated virtual network that you define.
data:image/s3,"s3://crabby-images/434ab/434ab1710e604903fcd181a10e3a77be53776734" alt=""
VS
data:image/s3,"s3://crabby-images/235fa/235fa2513adac846dd8b273a2e523a56c5201726" alt=""
data:image/s3,"s3://crabby-images/933eb/933eb889f79573b657452ef6ed17f9215248b959" alt=""
Setup
data:image/s3,"s3://crabby-images/cc0b7/cc0b71953d565b70af15360d623731a8e56ef454" alt=""
data:image/s3,"s3://crabby-images/fb243/fb2434dcf15679fa659aa0f90a7bf9d986922c51" alt=""
Test aws cli
data:image/s3,"s3://crabby-images/34e4b/34e4b1c38fe07be3224f37fd46b705e0ebe9c9cb" alt=""
Don't forget to add AmazonEC2FullAccess , EksAllAccess , IamLimitedAccess , and AWSCloudFormationFullAccess to your EKS user
User EKS permissions
Setup eksctl
apiVersion: eksctl.io/v1alpha5
kind: ClusterConfig
metadata:
name: basic-cluster
region: eu-north-1
nodeGroups:
- name: ng-1
instanceType: m5.large
desiredCapacity: 10
volumeSize: 80
ssh:
allow: true # will use ~/.ssh/id_rsa.pub as the default ssh key
- name: ng-2
instanceType: m5.xlarge
desiredCapacity: 2
volumeSize: 100
ssh:
publicKeyPath: ~/.ssh/ec2_id_rsa.pub
Cluster example configuration
eksctl create cluster -f file.yaml
Now lets create a cluster
Execute it and wait ~20 minutes
data:image/s3,"s3://crabby-images/cce3e/cce3ead061ad22c05a87dfd51eca3d9507bfb061" alt=""
data:image/s3,"s3://crabby-images/b040c/b040c5c890e171cd4a2f126d5c485621df9b4c68" alt=""
data:image/s3,"s3://crabby-images/81d74/81d74d761c09e39ee3b62394b445018175b101b1" alt=""
data:image/s3,"s3://crabby-images/e7c6b/e7c6bf124eea1408b0d817ce113bbfd5178b378d" alt=""
data:image/s3,"s3://crabby-images/c8635/c863553a2a45dc28cfbf4dedc673bd913d153e36" alt=""
Deploy chat
data:image/s3,"s3://crabby-images/d16ba/d16baf14b60b3d855d8e6bc2eebb15ea412e9cd0" alt=""
#!/bin/bash
# Create namespace for kafka
kubectl create ns kafka
# Setup helm to be able to use bitnami charts
helm repo add bitnami https://charts.bitnami.com/bitnami
#Basic mongo
helm install my-mongo bitnami/mongodb
# Redis with 0 slaves to save resources
helm install my-redis --set cluster.slaveCount=0 bitnami/redis
#Kafka
helm install my-kafka --namespace kafka -f 07-kafka-config.yaml bitnami/kafka
# Chat + Users API + Client
kubectl apply -f 01-user-service.yaml
kubectl apply -f 02-chat-service.yaml
kubectl apply -f 03-chat-app.yaml
# Traefik
kubectl apply -f 04-traefik-rbac.yaml
kubectl apply -f 05-traefik-deployment.yaml
kubectl apply -f 06-traefik-ingress-routes.yaml
# Facebook oauth servcie
kubectl apply -f 08-auth-middleware.yaml
Execute following script
data:image/s3,"s3://crabby-images/c81a9/c81a911b49b6d810dd4ece9250012f5239536aa2" alt=""
Check chat-service logs
data:image/s3,"s3://crabby-images/9c321/9c321195601211817d78a3dd7ade39f94b621103" alt=""
Find Traefik svc LoadBalancer DNS name
data:image/s3,"s3://crabby-images/89925/89925826626c020b4e2588cb1a2a7b391a23eb71" alt=""
Check all routes are helthy
data:image/s3,"s3://crabby-images/3cf78/3cf785b172353353e8f7a0835b7bf0f71fe33cfa" alt=""
Configure DNS to map your domain to a Traefik LB
data:image/s3,"s3://crabby-images/8ebac/8ebac298f5090fc62fc8d7542831e1da4423fc7b" alt=""
Finally it works in the cloud
data:image/s3,"s3://crabby-images/cf26e/cf26ec46143b43c9fb1aab51dc7f9133d7dea377" alt=""
$ Pricing
data:image/s3,"s3://crabby-images/8f36c/8f36cc76a13e19a4f421c605f274a5ab8305d4cf" alt=""
Service
1d (24h)
1m
EKS control plane
$2.4
1x EC2 t2.large (2Cores, 8GB RAM)
$2.4
10x EC2 t2.micro (1Core, 1GB RAM)
$2.4
24 GB EBS Volumes GP2
$2.4
1x DNS Hosted zone (Route 53)
$0.5
Total
$0.08
$0.015
$7.3
$72
$72
$72
$219
Content
Nest.js quick start
Databases
Docker
CI / CD
Caching
Nest.js + WebSocket
Kubernetes
Load balancing & Ingress
Messaging queues
Authentication & authorization
AWS
Deploy app to EKS
data:image/s3,"s3://crabby-images/cb5da/cb5da895ef9de460ee35bd523568686d56ff5a06" alt=""
Course contributors
data:image/s3,"s3://crabby-images/4a468/4a4680a2d2dc35656ab8997abad220d1448043dc" alt=""
Inna Ivashchuk
Senior Software Engineer
data:image/s3,"s3://crabby-images/54aa4/54aa42506b392c26c9ea56ddd90d6e388f2bd04a" alt=""
Dmytro Bielik
Senior Software Engineer
Trainers
Guests
Vladyslav Matus
Solution Architect
data:image/s3,"s3://crabby-images/cf2e9/cf2e9e642f3e199d13667e36cd0baccc07f858ac" alt=""
Oleksandr Fedirko
Solution Architect
data:image/s3,"s3://crabby-images/921bb/921bbfe2d0ba0a515a92ed5e2b0c9e41804f2f20" alt=""
Denys Vasyliev
Lead Software Engineer
Volodymyr Vyshko
Lead Software Engineer
data:image/s3,"s3://crabby-images/ea041/ea0413f1e2b521a44b2f5af87620c3118df4d674" alt=""
Organizers
Ivan Andreiev
Technology Manager
Tatiana Gusar
Lead Specialist
data:image/s3,"s3://crabby-images/ec7d7/ec7d73709f5d879fb9742fe2a3abb98c086c2b29" alt=""
Kateryna Marunyak
Specialist
Oleksandra Kovalchuk
Junior Specialist
data:image/s3,"s3://crabby-images/16ba4/16ba458d1316b2bcb819dfeba0f7449d5714ac94" alt=""
data:image/s3,"s3://crabby-images/92547/92547643eeddc0ea02c8ffc8d2f029cc81461bbc" alt=""
data:image/s3,"s3://crabby-images/00597/00597f054b30a7904011bfbe3ef6463e8017abad" alt=""
data:image/s3,"s3://crabby-images/eb134/eb1341c7eb53a651c6833c46000e5943a5352a6d" alt=""
data:image/s3,"s3://crabby-images/2d96f/2d96f1946d4a14c704767f0e14c7a5ae301b82b4" alt=""
data:image/s3,"s3://crabby-images/67217/67217a8a3f1fd301b8397ad9e5f113adc3a2bed8" alt=""
Thank You!
data:image/s3,"s3://crabby-images/b6f2b/b6f2b5f2449a3e1d6ca5160b11de51e2c5f26a0d" alt=""
Distributed Node #12
By Vladimir Vyshko
Distributed Node #12
EKS
- 685