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.
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
-
Read more AWS CDK:
https://github.com/aws/aws-cdk -
Read more about parallel AWS CDK deployments:
https://github.com/aws/aws-cdk/issues/1973
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.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
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
Built Distribution
File details
Details for the file b_aws_cdk_parallel-1.0.0.tar.gz
.
File metadata
- Download URL: b_aws_cdk_parallel-1.0.0.tar.gz
- Upload date:
- Size: 10.5 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
Algorithm | Hash digest | |
---|---|---|
SHA256 | a7ed4a2b82e94b0e39890b8e21fa250f31ec8c00185535dd8acbb45e34c5c5bb |
|
MD5 | 5cc13c541e6fc2880a1feab02f7965df |
|
BLAKE2b-256 | 996c4ef6e17c0ceae3eb1ad0c14860bd1e4ae06d3dcb8cd8a5f9fddab6c9e0e5 |
File details
Details for the file b_aws_cdk_parallel-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: b_aws_cdk_parallel-1.0.0-py3-none-any.whl
- Upload date:
- Size: 11.3 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
Algorithm | Hash digest | |
---|---|---|
SHA256 | bb51a120517087c37bdfd79262a3658fe9a07a7de8fe4c966b36fb629246bfc3 |
|
MD5 | 4954954e18abbae464eed70f1213cb62 |
|
BLAKE2b-256 | 31c78d63b3e8a5e063d28c1a47da34b758fafd6f4cac8a11a1ccef572d51f740 |