AWS CDK based lambda layer including useful utilities.
Project description
B.CfnLambdaLayer
Easy lambda dependency management is here!
This is an AWS CDK resource that acts as a
LayerVersion
resource but with more convenient approach to specify and bundle dependencies.
Description
AWS CDK already makes it incredibly simple to package code for lambda functions and
layers by exposing Code
resource and methods like Code.from_asset()
. However, it is very
difficult to add additional dependencies to your layer code e.g. jose
, requests
, newer boto3
library, etc.
This custom layer resource makes packaging code with dependencies extremely simple like 2 + 2! You
simply specify a dictionary of dependencies to include and this resource will do the rest.
You should note that this resource uses docker
to bundle code and dependencies.
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
- Python3
- Docker
- AWS CDK
- AWS CloudFormation
- AWS Lambda
- AWS Lambda Layer
- AWS Lambda Layer bundling with Docker
Assumptions
This project assumes you know what Lambda functions are and how code is being shared between them (Lambda layers).
- Excellent knowledge in IaaC (Infrastructure as a Code) principles.
- Excellent knowledge in Lambda functions and Lambda layers.
- Good experience in AWS CDK and AWS CloudFormation.
- Good Python skills and basis of OOP.
Useful sources
- AWS CDK:
https://docs.aws.amazon.com/cdk/api/latest/docs/aws-construct-library.html - AWS CloudFormation:
https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/Welcome.html - Lambda layers:
https://docs.aws.amazon.com/lambda/latest/dg/configuration-layers.html - Lambda layers in AWS CDK:
https://docs.aws.amazon.com/cdk/api/latest/python/aws_cdk.aws_lambda/README.html
Install
Before installing this library, ensure you have these tools setup:
- Python / Pip
- AWS CDK
- Docker
To install this project from source run:
pip install .
Or you can install it from a PyPi repository:
pip install b-cfn-lambda-layer
Usage & Examples
Dependencies
The most convenient feature of this resource is easy dependency management. When creating a new layer you simply supply a dictionary of dependencies, and they will be installed and packaged to you layer at a deployment level:
from b_cfn_lambda_layer.package_version import PackageVersion
dependencies = {
'python-jose': PackageVersion.from_string_version('3.3.0'),
'boto3': PackageVersion.from_string_version('1.16.35'),
'botocore': PackageVersion.from_string_version('1.19.35')
}
Full example
This is a full example where we create a lambda layer and use it in lambda function.
from aws_cdk.aws_lambda import Function, Code, Runtime
from aws_cdk import Stack
from b_cfn_lambda_layer.lambda_layer import LambdaLayer
from b_cfn_lambda_layer.package_version import PackageVersion
# Create layer with custom dependencies.
layer = LambdaLayer(
scope=Stack(...),
name='TestLayer',
# You can conveniently specify path to source code to include.
# Or not specify it at all if you care only about dependencies.
# source_path=None,
source_path='/path/to/your/layer/source/code',
code_runtimes=[Runtime.PYTHON_3_8, Runtime.PYTHON_3_9, Runtime.PYTHON_3_10],
# You can conveniently specify dependencies to include.
dependencies={
'python-jose': PackageVersion.from_string_version('3.3.0'),
'boto3': PackageVersion.from_string_version('1.16.35'),
'botocore': PackageVersion.from_string_version('1.19.35')
}
)
# Create a function with a layer.
Function(
scope=Stack(...),
id='MyFunction',
code=Code.from_asset('/path/to/lambda/function/code'),
handler='index.handler',
runtime=Runtime.PYTHON_3_10,
# Specify layers.
layers=[layer]
)
Using layers in multiple stacks
We all know that we can not really share a lambda layer instance in multiple stacks. If we do, the next update to the source code in the lambda layer would result in a failed deployment. This is because of cross-stack exports-imports. An example error is given below:
2022-04-28 17:29:34 [ INFO] Stack | 2/4 | 5:29:31 PM | UPDATE_ROLLBACK_IN_P | AWS::CloudFormation::Stack | Stack Export Stack:Export cannot be updated as it is in use by StackB
Thankfully, this resource has solved the problem very conveniently.
Firstly, create a layer in any stack you want:
# Create the layer in any stack.
layer = LambdaLayer(
scope=Stack(...),
...
)
Then add it to a lambda function:
# Create a lambda function in any stack.
function = Function(
scope=Stack(...),
# DO NOT supply the layer directly as it will create a direct dependency
# between the function and the layer. This is what causes the deployments
# to fail if we update layer's source code.
# layers=[layer]
...
)
# Instead, call "add_to_function" layer's method to enable that layer for the function.
# This method does not create a direct dependency effectively solving cross-stack problems.
layer.add_to_function(function)
Testing
This package has integration tests based on pytest. To run tests simply run:
pytest b_cfn_lambda_layer_test/integration/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
3.0.0
- Upgrade CDK support from v1 to v2.
- Update GitHub pipelines checkout, setup-node and setup-python versions.
2.4.1
- Fix package manifest.
2.4.0
- Now you no longer need to specify a path to source code. You can have an absolutely empty layer if you desire so.
2.3.0
- Allow to add a list of lambda functions.
- Fix bug "Given ID already exists in stack...".
2.2.0
- Implement an ability to reference this layer in different stacks and avoid cross-stack errors. THIS IS HUGE.
2.1.1
- Even better backwards compatibility (Docker image still can be supplied as object).
2.1.0
- Improve backwards compatibility.
2.0.3
- Add missing Dockerfile in MANIFEST.
2.0.2
- Fix type hints.
2.0.1
- Actually, make it compatible with previous versions
(at least from the
layer_name
->name
perspective).
2.0.0
- Complete code refactor.
- Change cmd line based bundling to Dockerfile based bundling.
- Deprecated
requirements.txt
functionality. The library will no longer install dependencies if arequirements.txt
file is found within source code.
1.1.3
- Retain dist-utils when bundling layer.
1.1.1
- Small bug fix to include parent directory only for source code.
1.1.0
- Add ability to include parent directory when bundling.
1.0.0
- Improve documentation.
- This is a fully working production-ready library.
0.0.2
- Add documentation.
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_cfn_lambda_layer-3.0.0.tar.gz
.
File metadata
- Download URL: b_cfn_lambda_layer-3.0.0.tar.gz
- Upload date:
- Size: 20.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c9766bb3ed0ba961d46b2e60d843c649be46f056129661382cbb6c5d8d229b89 |
|
MD5 | d1b0a47d3b7f1136aaa6437241ecb1d9 |
|
BLAKE2b-256 | c839da26c25c8721b32cb6e55b22b54a7e3125613fb3cd41c292a621d4fee4e4 |
File details
Details for the file b_cfn_lambda_layer-3.0.0-py3-none-any.whl
.
File metadata
- Download URL: b_cfn_lambda_layer-3.0.0-py3-none-any.whl
- Upload date:
- Size: 31.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 813950f1eb569e3809bbdb65ab38b72a9cabca143ce7ac35370c5f41597c1399 |
|
MD5 | 05d584489f6f6cb5e584653e7eaba609 |
|
BLAKE2b-256 | 415cadbbaf4bd0e3f74aa1b7c942d7d56411ad28039c04c996684846900b71c6 |