Skip to main content

Package that enables deployment of AWS CDK stacks in parallel.

Project description

B.AwsCdkParallel

A python based package that enables AWS CDK parallel stack deployments.

Description

One of the biggest downsides of AWS CDK IaC tool is the sequential deployments. If you have many stacks within your project - it can take hours and hours till everything gets deployed. Wouldn't it be cool to parallelize them? According to AWS CDK tool maintainers - they are not even thinking right now to include such functionality. Hence, this project was built. This project allows you to run traditional cdk deploy * and cdk destroy * -f. But the main trick is that it can do it in parallel - massively increasing the speed of your deployments.

Remarks

Biomapas aims to modernise life-science industry by sharing its IT knowledge with other companies and the community. This is an open source library intended to be used by anyone. Improvements and pull requests are welcome.

Some techniques and inspirations were taken from this blog post:
https://taimos.de/blog/deploying-your-cdk-app-to-different-stages-and-environments

General issue is being discussed on github:
https://github.com/aws/aws-cdk/issues/1973

Related technology

  • Python 3
  • AWS CDK
  • AWS CloudFormation

Assumptions

The project assumes the following:

  • You have basic-good knowledge in python programming.
  • You have basic-good knowledge in AWS.
  • You have very good knowledge in AWS CDK.

Useful sources

Install

The project is built and uploaded to PyPi. Install it by using pip.

pip install b_aws_cdk_parallel

Or directly install it through source.

pip install .

Usage & Examples

from parallel.deployment_executor import DeploymentExecutor
from parallel.deployment_type import DeploymentType

if __name__ == '__main__':
    executor = DeploymentExecutor(type=DeploymentType.DEPLOY)
    executor.run()

Testing

This project currently has no tests.

Contribution

Found a bug? Want to add or suggest a new feature?
Contributions of any kind are gladly welcome. You may contact us directly, create a pull-request or an issue in github platform. Lets modernize the world together.

Release history

1.3.0

  • Do not rebuild assets on destroy.

1.2.0

  • Do not rebuild assets on deployment.

1.1.0

  • Add ability to control maximum parallel deployments.

1.0.0

  • Complete rework of the project. Build a dependency tree to determine what to deploy.

0.4.1

  • Raise exception in case of a failed deployment.

0.4.0

  • Cdk list command should also receive path and environment.

0.3.0

  • Add ability to specify CDK path and environment variables for processes.

0.2.0

  • Add ability to retry main deployment too.

0.1.0

  • Refactor project to make it more debug-friendly.

0.0.2

  • Upgrade dependencies.

0.0.1

  • Initial build.

Project details


Download files

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

Source Distribution

b_aws_cdk_parallel-1.3.0.tar.gz (10.9 kB view details)

Uploaded Source

Built Distribution

b_aws_cdk_parallel-1.3.0-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file b_aws_cdk_parallel-1.3.0.tar.gz.

File metadata

  • Download URL: b_aws_cdk_parallel-1.3.0.tar.gz
  • Upload date:
  • Size: 10.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.23.0 setuptools/47.0.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.5

File hashes

Hashes for b_aws_cdk_parallel-1.3.0.tar.gz
Algorithm Hash digest
SHA256 ccb8608a3cb14a4c34e1aa6c649c5efad43b7bc86f732ad07eaef99ae455bc2c
MD5 d9e6a8068da940b4c73519889d707479
BLAKE2b-256 6bcab962d70ad7a5c47f250166eba8c3d9b5121bfe6461aabf5000b6a4cf94f6

See more details on using hashes here.

File details

Details for the file b_aws_cdk_parallel-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: b_aws_cdk_parallel-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 11.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.23.0 setuptools/47.0.0 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.5

File hashes

Hashes for b_aws_cdk_parallel-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f26c362d192faa067991f34c89a2db81aa355916ae86c7c20af626b77b1cb74f
MD5 9c77e59ae63f32b8f01864f9e073073f
BLAKE2b-256 ffaf81965a39fa5407dad6ceeda1efbcc92e4ee3ae9e68de4a7cca62d6a36cec

See more details on using hashes here.

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