This is a CDK construct library that aims to accelerate your experiment on LLRT, a lightweight JavaScript runtime for AWS Lambda.
Install it via npm:
npm install cdk-lambda-llrtThen you can use LlrtFunction construct. Just set an entry point for the function.
import { LlrtFunction } from 'cdk-lambda-llrt';
const handler = new LlrtFunction(this, 'Handler', {
entry: 'lambda/index.ts',
});If you are already using NodejsFunction construct, you should be able to just replace it to LlrtFunction.
Warning
LLRT is currently experimental and not fully compatible with Node.js. You should expect some trial and errors to use LLRT with your existing code.
By default the latest version of LLRT is fetched from GitHub (unless you set llrtVersion). This LLRT binary is cached, in a .tmp directory or inside a docker image if you set useLambdaLayer.
If you want to upgrade the LLRT version you will need to remove the .tmp directory or remove the docker images (the images can be identified during the cdk build e.g. docker.io/library/cdk-926fb3006b78cf5a5efe8e6485491147c08a50b8ada8272a6761a8ddc85b2aec:latest and can be removed using docker image rm <image>).
In some cases, your code may run successfully on LLRT by setting bundle target platform to browser. You can configure it by the following code:
import { LlrtFunction } from 'cdk-lambda-llrt';
const handler = new LlrtFunction(this, 'Handler', {
entry: 'lambda/index.ts',
bundling: {
esbuildArgs: { '--platform': 'browser' },
}
});In some environments, LlrtFunction's bundling steps will fail because the underlying NodejsFunction sometimes runs the commands on your host machine, and your environment does not support these commands or syntax. To avoid this error, you can force docker bundling for these commands not to depend on your execution environment.
new LlrtFunction(this, 'Handler', {
entry: 'handler.ts',
bundling: {
forceDockerBundling: true, // Add this!
},
});Note that we enable this flag automatically on Windows platform.
LLRT publishes several types of binaries with different sets of bundled SDKs:
LlrtBinaryType.FULL_SDK: Includes all AWS SDKsLlrtBinaryType.NO_SDK: No AWS SDKs includedLlrtBinaryType.STANDARD: Standard bundle (default)
You can specify the binary type when creating a new LlrtFunction:
const handler = new LlrtFunction(this, 'Handler', {
entry: 'lambda/index.ts',
llrtBinaryType: LlrtBinaryType.FULL_SDK,
});By default, CDK Lambda LLRT downloads the LLRT bootstrap binary from LLRT's GitHub releases and caches this in the .tmp directory.
If you have your own bootstrap binary you want to use, you can specify the relative path from the function's projectRoot directory with the llrtBinaryPath property.
const handler = new LlrtFunction(this, 'Handler', {
entry: 'lambda/index.ts',
llrtBinaryPath: '.llrt/bootstrap'
});By default, CDK Lambda LLRT bundles the LLRT bootstrap binary directly in your lambda function.
If you want to package the binary in a separate layer that can be shared amongst functions then set llrtLayer to true.
const handler = new LlrtFunction(this, 'Handler', {
entry: 'lambda/index.ts',
llrtLayer: true
});See example for examples to use LlrtFunction construct.