2021-01-04 14:30:14 +01:00
|
|
|
---
|
|
|
|
title: ECS integration architecture
|
|
|
|
description: Mapping of Docker compose entities to Amazon constructs
|
|
|
|
keywords: Docker, Amazon, Integration, ECS, Compose, architecture, mapping
|
|
|
|
---
|
2020-09-23 07:15:55 +02:00
|
|
|
# Architecture
|
|
|
|
|
2021-08-09 11:50:40 +02:00
|
|
|
ECS integration relies on CloudFormation to manage AWS resources as an atomic operation.
|
2020-09-23 07:15:55 +02:00
|
|
|
This document describes the mapping between compose application model and AWS components
|
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
|
|
|
This diagram shows compose model and on same line AWS components that get created as equivalent resources
|
|
|
|
|
|
|
|
```
|
2020-09-30 14:35:07 +02:00
|
|
|
+----------+ +-------------+ +-------------------+
|
|
|
|
| Project | . . . . . . . . . . . . . . | Cluster | . . . . . . . | LoadBalancer |
|
|
|
|
+-+--------+ +-------------+ +-------------------+
|
2020-09-23 07:15:55 +02:00
|
|
|
|
|
2021-01-04 14:30:14 +01:00
|
|
|
| +----------+ +-------------++-------------------+ +-------------------+
|
|
|
|
+----+ Service | . . . . . . . . . . | Service || TaskDefinition | | TargetGroup |
|
|
|
|
| +--+-------+ +-------------++-------------------+-+ +-------------------+
|
|
|
|
| | | TaskRole |
|
|
|
|
| | +-------------------+-+
|
|
|
|
| | x-aws-role, x-aws-policies . . . . . . . . | TaskExecutionRole |
|
|
|
|
| | +-------------------+
|
2020-09-30 14:35:07 +02:00
|
|
|
| | +---------+
|
|
|
|
| +--+ Deploy |
|
|
|
|
| | +---------+ +-------------------+
|
2020-10-19 01:57:00 +02:00
|
|
|
| | x-aws-autoscaling . . . . . . | ScalableTarget |
|
2020-09-30 14:35:07 +02:00
|
|
|
| | +-------------------+---+
|
|
|
|
| | | ScalingPolicy |
|
|
|
|
| | +-------------------+-+
|
|
|
|
| | | AutoScalingRole |
|
|
|
|
| | +-------------------+
|
2020-09-23 07:15:55 +02:00
|
|
|
| |
|
2020-09-30 14:35:07 +02:00
|
|
|
| | +---------+ +-------------+ +-------------------+
|
|
|
|
| +--+ Ports | . . . . . . . | IngressRule +-----+ | Listener |
|
|
|
|
| | +---------+ +-------------+ | +-------------------+
|
|
|
|
| | |
|
2020-09-23 07:15:55 +02:00
|
|
|
| | +---------+ +---------------+ +------------------+
|
2020-09-30 14:35:07 +02:00
|
|
|
| +--+ Secrets | . . . . . . . | InitContainer | |TaskExecutionRole |
|
2020-09-23 07:15:55 +02:00
|
|
|
| | +---------+ +---------------+ +------------+-----+
|
2020-09-30 14:35:07 +02:00
|
|
|
| | | |
|
|
|
|
| | +---------+ | |
|
|
|
|
| +--+ Volumes | | |
|
|
|
|
| | +---------+ | |
|
|
|
|
| | | |
|
|
|
|
| | +---------------+ | | +-------------------+
|
|
|
|
| +--+ DeviceRequest | . . . . . . . . . . . . . . . | . . . . | . . . | CapacityProvider |
|
|
|
|
| +---------------+ | | +-------------------+--------+
|
|
|
|
| | | | AutoscalingGroup |
|
|
|
|
| +------------+ +---------------+ | | +---------------------+
|
|
|
|
+---+ Networks | . . . . . . . . . | SecurityGroup +---+ | | LaunchConfiguration |
|
|
|
|
| +------------+ +---------------+ | +---------------------+
|
2020-09-23 07:15:55 +02:00
|
|
|
| |
|
|
|
|
| +------------+ +---------------+ |
|
2020-09-30 14:35:07 +02:00
|
|
|
+---+ Secret | . . . . . . . . . | Secret +--------------+
|
2020-09-23 07:15:55 +02:00
|
|
|
+------------+ +---------------+
|
|
|
|
```
|
|
|
|
|
2021-04-20 20:06:31 +02:00
|
|
|
Each compose application service is mapped to an ECS `Service`. A `TaskDefinition` is created according to compose definition.
|
2020-09-23 07:15:55 +02:00
|
|
|
Actual mapping is constrained by both Cloud platform and Fargate limitations. Such a `TaskDefinition` is set with a single container,
|
|
|
|
according to the compose model which doesn't offer a syntax to support sidecar containers.
|
|
|
|
|
2021-01-04 14:30:14 +01:00
|
|
|
An IAM Role is created and configured as `TaskRole` to grant service access to additional AWS resources when required. For this
|
2020-09-23 07:15:55 +02:00
|
|
|
purpose, user can set `x-aws-policies` or define a fine grained `x-aws-role` IAM role document.
|
|
|
|
|
|
|
|
Service's ports get mapped into security group's `IngressRule`s and load balancer `Listener`s.
|
|
|
|
Compose application whith HTTP services only (using ports 80/443 or `x-aws-protocol` set to `http`) get an Application Load Balancer
|
|
|
|
created, otherwise a Network Load Balancer is used.
|
|
|
|
|
|
|
|
A `TargetGroup` is created per service to dispatch traffic by load balancer to the matching containers
|
|
|
|
|
|
|
|
Secrets bound to a service get translated into an `InitContainer` added to the service's `TaskDefinition`. This init container is
|
|
|
|
responsible to create a `/run/secrets` file for secret to match docker secret model and make application code portable.
|
|
|
|
A `TaskExecutionRole` is also created per service, and is updated to grant access to bound secrets.
|
|
|
|
|
|
|
|
Services using a GPU (`DeviceRequest`) get the `Cluster` extended with an EC2 `CapacityProvider`, using an `AutoscalingGroup` to manage
|
|
|
|
EC2 resources allocation based on a `LaunchConfiguration`. The latter uses ECS recommended AMI and machine type for GPU.
|
|
|
|
|
2020-09-30 14:35:07 +02:00
|
|
|
Service to declare `deploy.x-aws-autoscaling` get a `ScalingPolicy` created targeting specified the configured CPU usage metric
|