Skip to main content

Implement for AWS ECS and Docker Compose what SAM is to Serverless for AWS Lambda

Project description

PYPI_VERSION PyPI - License PY_DLS

CodeStyle TDD with pytest BDD with Behave

Code scan with SonarCloud

BUILD

Manage, Configure and deploy your applications/services and AWS resources from your docker-compose definitions

Why use ECS Compose-X?

As a developer, working locally is a crucial part of your day to day work, and docker-compose allows you to do just that, for simple services as well as very complex structures.

Your prototype works, and you want to deploy to AWS. But what about IAM ? Networking ? Security ? Configuration ?

Using ECS Compose-X, you keep your docker-compose definitions as they are, add the AWS services you have chosen as part of that definition, such as ELB, RDS/DynamodDB Databases etc, and the program will automatically generate all the AWS CloudFormation templates required to deploy all your services.

It automatically takes care of network access requirements and IAM permissions, following best practices.

Installation

ECS Compose-X can be used as a CLI ran locally, in CICD pipelines, or as an AWS CloudFormation macro, allowing you to use your Docker Compose files directly in CloudFormation!

On AWS using AWS CloudFormation Macro

You can now deploy the CloudFormation macro to your AWS Account using AWS Serverless Application Repository (SAR).

Deploy it in your account today AWS_SAR

Find out how to use ECS Compose-X in AWS here

Via pip

pip install ecs_composex

CLI Usage

usage: ecs-compose-x [-h] {up,render,create,plan,config,init,version} ...

positional arguments:
  {up,render,create,plan,config,init,version}
                        Command to execute.
    up                  Generates & Validates the CFN templates, Creates/Updates stack in CFN
    render              Generates & Validates the CFN templates locally. No upload to S3
    create              Generates & Validates the CFN templates locally. Uploads files to S3
    plan                Creates a recursive change-set to show the diff prior to an update
    config              Merges docker-compose files to provide with the final compose content version
    init                Initializes your AWS Account with prerequisites settings for ECS
    version             ECS ComposeX Version

optional arguments:
  -h, --help            show this help message and exit

Examples

# Render all your CFN templates from your docker compose and extension files
ecs-compose-x render --format yaml -n my-awesome-app -f docker-compose.yml -f aws.yml -d outputs

# Deploy / Update your application to AWS
ecs-compose-x up --format yaml -n my-awesome-app -f docker-compose.yml -f aws.yml -d outputs

Features

AWS Services support

To have an extensive list of support, refer to the compatibilty matrix and the syntax reference for each AWS services in our documentation

How is it different ?

There are a lot of similar tools out there, including published by AWS. So here are a few of the features that we think could be of interest to you.

Modularity / “Plug & Play”

The majority of people who are going to use ECS ComposeX on a daily basis should be developers who need to have an environment of their own and want to quickly iterate over it.

However, it is certainly something that Cloud Engineers in charge of the AWS accounts etc. would want to use to make their own lives easy too.

In many areas, you as the end-user of ComposeX will already have infrastructure in place: VPC, DBs and what not. So as much as possible, you will be able in ComposeX to define Lookup sections which will find your existing resources, and map these to the services.

Built for AWS Fargate

However the original deployments and work on this project was done using EC2 instances (using SpotFleet), everything is now implemented to work on AWS Fargate First (2020-06-06).

That said, all features that can be supported with EC2 instances are available to you with ECS Compose-X, which, will simply disable such settings when deployed on top of AWS Fargate.

Attributes auto-correct

A fair amount of the time, deployments via AWS CloudFormation, Ansible and other IaC will fail because of incompatible settings. This happened a number of times, with a lot of different AWS Services.

Whilst giving you the ability to use all properties of AWS CloudFormation objects, whenever possible, ECS Compose-X will understand how two services are connected and will auto-correct the settings for you.

For example, if you set the Log retention to be 42 days, which is invalid, it will automatically change that to the closest valid value (here, 30).

Documentation

Find all the documentation to get started and and start deploying to AWS

RoadMap

Blog

Follow the latest publications on our blog

Credits

This package would not have been possible without the amazing job done by the AWS CloudFormation team! This package would not have been possible without the amazing community around Troposphere! This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ecs_composex-0.15.6.tar.gz (299.0 kB view details)

Uploaded Source

Built Distribution

ecs_composex-0.15.6-py2.py3-none-any.whl (281.3 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file ecs_composex-0.15.6.tar.gz.

File metadata

  • Download URL: ecs_composex-0.15.6.tar.gz
  • Upload date:
  • Size: 299.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.1.3 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.6

File hashes

Hashes for ecs_composex-0.15.6.tar.gz
Algorithm Hash digest
SHA256 7621cd69e019372b9c69cd8d2220dda293018d392ef9ee3557b07253601b9bf9
MD5 5c58d48e4d38eb782edfccb8f7596366
BLAKE2b-256 01eb4ca91ddd42c34b077becd755c167baf4231ac54cde3a6fbb155ecd8f61d7

See more details on using hashes here.

Provenance

File details

Details for the file ecs_composex-0.15.6-py2.py3-none-any.whl.

File metadata

  • Download URL: ecs_composex-0.15.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 281.3 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.1.3 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.6

File hashes

Hashes for ecs_composex-0.15.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 8b90371eb945f38ecac8797516cda58ca6b2961dcc2e915a9d4aa92c8c6ee7f2
MD5 475ae097d2ff991bf3b531a2daad4715
BLAKE2b-256 3370cd2b8bd376e077d87b88372e0874feb84d151fd078a507bc76f9e095aa2f

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page