Join me here :
CONTAINERS on AWS
-
INTRODUCTION
-
AWS NATIVE STACK
-
Kubernetes on AWS
-
AWS NATIVE STACK V2
-
Demo
-
WRAP-UP
Mohamed BOUCHENAFA
DevOps/Cloud Lead Consultant
Docker Geneva Community Leader
data:image/s3,"s3://crabby-images/1f58e/1f58ea01f98757aa43ed151d5c22460b7c10afa7" alt=""
data:image/s3,"s3://crabby-images/272e9/272e98a7ea9084e6875191da5b7327cf8cb08f0d" alt=""
data:image/s3,"s3://crabby-images/2bdbf/2bdbf1ff1571da25dd02dcaf2167032013f21bc1" alt=""
data:image/s3,"s3://crabby-images/714e8/714e81c44dc7c838ba94efbaadad9d269cefe9ef" alt=""
THE TEAM
7 consultants
- Support to DevOps transition
- Support to container transition
- CI/CD expertise
- Deployment expertise
- Release management expertise
- Provisioning automation
- Monitoring
- Cloud migration
- Cloud audit & optimization
data:image/s3,"s3://crabby-images/347f7/347f7fad6dd0d43f98a0febbef4a9699f8299404" alt=""
Join me here :
data:image/s3,"s3://crabby-images/9327f/9327f0f0f1a0bdc689cca45110ed17c0f95b12b0" alt=""
data:image/s3,"s3://crabby-images/4b1dd/4b1ddf218e94d1b28de97d2aeb1b5970bdbe690d" alt=""
EC2
VPC
S3
EBS
EFS
IAM
CLOUDFORMATION
ELB
CERTIFICATE MANAGER
REGIONS AND AVAILABILITY ZONES
data:image/s3,"s3://crabby-images/44317/443177b00d95aa8ebe5a8cec69a4faf53caf1c69" alt=""
data:image/s3,"s3://crabby-images/4c01a/4c01a4bebc7bd8811a2b278adad16c67a3e868a7" alt=""
High Availability
data:image/s3,"s3://crabby-images/e1ac4/e1ac4c54500a660976f846cc28fa3c22cfb62029" alt=""
an open-source system for packaging software into standardized units (called containers) for development, shipment and deployment
> ssh -i my-ec2-key-pair.pem ec2-user@<EC2-INSTANCE-PUBLIC-IP-ADDRESS>
[ec2-user]$ sudo yum update -y
[ec2-user]$ sudo yum install -y docker
[ec2-user]$ sudo service docker start
[ec2-user]$ sudo usermod -a -G docker ec2-user
[ec2-user]$ docker run -d -p 80:5000 training/webapp:latest python app.py
[ec2-user]$ curl http://localhost
Hello world!
AT THE BEGINNING
THIS MEANS
data:image/s3,"s3://crabby-images/5b710/5b710a7096fc6b64cb0b50c0cf74694814d4ee41" alt=""
THEN
data:image/s3,"s3://crabby-images/0be44/0be44cb531b96eaa0420ac5e88e92b6d8abc3f50" alt=""
data:image/s3,"s3://crabby-images/7f59d/7f59da0d3c0f6205f0f01420009dd17ac193f8e5" alt=""
MUST BE A BETTER SOLUTION ?
data:image/s3,"s3://crabby-images/39e25/39e2595739d43eee28372d1363476b1c28993337" alt=""
data:image/s3,"s3://crabby-images/a010a/a010a96914410c0a2edb1b17f365972db9d852d0" alt=""
data:image/s3,"s3://crabby-images/23f3f/23f3f1473f0a783bc279490bd44bab66d4705b37" alt=""
data:image/s3,"s3://crabby-images/0be44/0be44cb531b96eaa0420ac5e88e92b6d8abc3f50" alt=""
data:image/s3,"s3://crabby-images/99823/99823c2e8d0616f6a4c85fc0f6f9318d728c0ec6" alt=""
data:image/s3,"s3://crabby-images/8e909/8e909fb416678713037909e96169a9803bf0a511" alt=""
data:image/s3,"s3://crabby-images/c49ce/c49ce7483c4bf38d14debcae435ad14e7a151e5d" alt=""
data:image/s3,"s3://crabby-images/c686c/c686c17d8f62bb4810353d1de41b088c9abeb87c" alt=""
data:image/s3,"s3://crabby-images/99823/99823c2e8d0616f6a4c85fc0f6f9318d728c0ec6" alt=""
data:image/s3,"s3://crabby-images/8e909/8e909fb416678713037909e96169a9803bf0a511" alt=""
data:image/s3,"s3://crabby-images/8e909/8e909fb416678713037909e96169a9803bf0a511" alt=""
data:image/s3,"s3://crabby-images/8e909/8e909fb416678713037909e96169a9803bf0a511" alt=""
Container definition
Task definition
Service
Cluster
ECS OBJECTS
{"ipcMode": null,
"executionRoleArn": null,
"containerDefinitions": [
{
******
"portMappings": [
{
"hostPort": 8081,
"protocol": "tcp",
"containerPort": 8081
}
],
******
"mountPoints": [
{
"readOnly": null,
"containerPath": "/var/opt/jfrog/artifactory/data",
"sourceVolume": "data"
}
],
"cpu": 744,
"memory": 812,
"memoryReservation": null,
"volumesFrom": [],
"image": "************.dkr.ecr.eu-west-1.amazonaws.com/sw_artifactory",
"disableNetworking": null,
"interactive": null,
"healthCheck": null,
"essential": true,
"links": null,
"hostname": null,
"extraHosts": null,
"pseudoTerminal": null,
"user": null,
"readonlyRootFilesystem": null,
"dockerLabels": null,
"systemControls": null,
"privileged": true,
"name": "artifactory"
}
],
"placementConstraints": [],
"memory": null,
"taskRoleArn": null,
"compatibilities": [
"EC2"
],
"taskDefinitionArn": "arn:aws:ecs:eu-west-1:************:task-definition/artifactory:6",
"family": "artifactory",
"requiresAttributes": [
{
"targetId": null,
"targetType": null,
"value": null,
"name": "com.amazonaws.ecs.capability.privileged-container"
},
{
"targetId": null,
"targetType": null,
"value": null,
"name": "com.amazonaws.ecs.capability.ecr-auth"
}
],
"pidMode": null,
"requiresCompatibilities": [],
"networkMode": "bridge",
"cpu": null,
"revision": 6,
"status": "ACTIVE",
"volumes": [
{
"name": "data",
"host": {
"sourcePath": "/mnt/data/artifactory/data"
},
"dockerVolumeConfiguration": null
},
{
"name": "logs",
"host": {
"sourcePath": "/mnt/data/artifactory/logs"
},
"dockerVolumeConfiguration": null
},
{
"name": "etc",
"host": {
"sourcePath": "/mnt/data/artifactory/etc"
},
"dockerVolumeConfiguration": null
}
]
}
"placementConstraints": [],
"memory": null,
"taskRoleArn": null,
"compatibilities": [
"EC2"
],
"taskDefinitionArn": "arn:aws:ecs:eu-west-1:************:task-definition/artifactory:6",
"family": "artifactory",
"requiresAttributes": [
{
"targetId": null,
"targetType": null,
"value": null,
"name": "com.amazonaws.ecs.capability.privileged-container"
},
{
"targetId": null,
"targetType": null,
"value": null,
"name": "com.amazonaws.ecs.capability.ecr-auth"
}
],
"pidMode": null,
"requiresCompatibilities": [],
"networkMode": "bridge",
"cpu": null,
"revision": 6,
"status": "ACTIVE",
"volumes": [
{
"name": "data",
"host": {
"sourcePath": "/mnt/data/artifactory/data"
},
"dockerVolumeConfiguration": null
}
]
}
Container Registry
- Fully Managed
- Secure
- Highly Available
- Simplified Workflow
data:image/s3,"s3://crabby-images/23f3f/23f3f1473f0a783bc279490bd44bab66d4705b37" alt=""
$(aws ecr get-login --no-include-email --region us-east-1)
an open-source system for automating deployment, scaling, and management of containerized applications across clusters of machines
of Kubernetes workloads
run on AWS today
— Cloud Native Computing Foundation
57%
+
data:image/s3,"s3://crabby-images/d67e4/d67e41269218c818a6c199c26cf729f8bc9f8211" alt=""
data:image/s3,"s3://crabby-images/c067b/c067b2dc6f65d291fe636bb66eeed964d0fe73ff" alt=""
USER
CONTROL PLANE
No instances to manage
Task native API
Resource based price
Simple, easy to use, powerful and new consumption model
-
IAM Roles for Tasks
-
Task Auto Scaling
-
Task Load Balancers
-
Task Networking
- Applications invoked by name
- Automatically resolved to IP or port
- Native to Amazon ECS services
- No infrastructure to manage
SERVICE DISCOVERY
WRAP UP
Large workload, optimized for price
Large workload, optimized for low overhead
Small workload, with occasional bursts
Tiny workload
Batch workloads
data:image/s3,"s3://crabby-images/3b6d7/3b6d711691dd25708fda23911fbbe46c3e862ed9" alt=""
data:image/s3,"s3://crabby-images/6c737/6c73738b7dbdffdf2ec7b2c578dc72bfd94d4213" alt=""
data:image/s3,"s3://crabby-images/3b6d7/3b6d711691dd25708fda23911fbbe46c3e862ed9" alt=""
data:image/s3,"s3://crabby-images/3b6d7/3b6d711691dd25708fda23911fbbe46c3e862ed9" alt=""
data:image/s3,"s3://crabby-images/3b6d7/3b6d711691dd25708fda23911fbbe46c3e862ed9" alt=""
data:image/s3,"s3://crabby-images/7f1ac/7f1acef2be14f03ac72699e472fc430090e60243" alt=""
Fargate mode for EKS : coming soon
data:image/s3,"s3://crabby-images/2427d/2427d48a65b8d114919edefbaf5f278122958bfd" alt="@AWSreInvent"
follow @AWSreInvent or join the recap
data:image/s3,"s3://crabby-images/744a2/744a228dfcbf2b5a78b488d5d090c0cfc10059c3" alt=""
CREDITS
- aws.amazon.com
- @nathankpeck
- @ric__harvey
- @tiffanyfayj
Containers on AWS
By Mohamed BOUCHENAFA
Containers on AWS
- 1,654