Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/viesti/clj-lambda-layered
A sample on how to split the lib deps of a JVM/Clojure lambda into a layer
https://github.com/viesti/clj-lambda-layered
Last synced: about 2 months ago
JSON representation
A sample on how to split the lib deps of a JVM/Clojure lambda into a layer
- Host: GitHub
- URL: https://github.com/viesti/clj-lambda-layered
- Owner: viesti
- Created: 2023-03-01T20:00:19.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-03-04T21:46:08.000Z (almost 2 years ago)
- Last Synced: 2024-11-12T01:35:12.345Z (about 2 months ago)
- Language: Clojure
- Size: 7.81 KB
- Stars: 16
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# JVM/Clojure Lambda with deps in a layer
## Rationale
AWS Lambda supports layers, so with a AWS provided JVM Runtime, we can put [library dependencies in a layer](https://docs.aws.amazon.com/lambda/latest/dg/configuration-layers.html#configuration-layers-path).
The code in this repository shows how to split a JVM/Clojure project into
* Lambda with only the handler namespace AOT compiled
* Layer with the library dependenciesThe AWS provided JVM Runtime looks up a handler class, with a specific event handler method, so we need to provide such a class.
The trick is to use [requiring-resolve](https://clojuredocs.org/clojure.core/requiring-resolve) in the Lambda handler, to compile only the handler and not all application code, and to [AOT only the handler namespace](https://github.com/viesti/clj-lambda-layered/blob/181c54488f5c39aee9674432b41238fbccc67e60/build.clj#L19).
Postponing Clojure code to bytecode compilation to happen during the first event handler invocation would make the first invocation slow, but with [AWS Lambda Snapstart](https://aws.amazon.com/blogs/aws/new-accelerate-your-lambda-functions-with-lambda-snapstart/), we can put the compilation to happen at the Snapstart invocation phase.
The code in this example makes the clojure compiler run at checkpoint creation time via [runtime hook](https://docs.aws.amazon.com/lambda/latest/dg/snapstart-runtime-hooks.html):
```clojure
(defn -beforeCheckpoint [this context]
(println "Before checkpoint")
;; Do stuff here that would result in compiling the clojure application code, so the resulting process state can be checkpointed via Firecracker VM
((requiring-resolve 'layer-demo.core/get-clojure))
(println "Before checkpoint done"))
```### Usage
Compile the lamdba via
```shell
clj -T:build lambda
```This produces `target/lambda.jar`, which you can upload to a Lambda with JVM runtime.
Compile the layer via
```shell
clj -T:build layer
```This produces `target-layer/layer.zip`, which you can upload as a layer. Select the layer for the Lambda to use.