#aws-lambda #tower-layer #axum #lambda #aws #tower

axum-aws-lambda

Tower Layer for compatibility between Axum and AWS Lambda Runtime

9 breaking releases

0.10.0 Jan 21, 2025
0.9.0 Oct 8, 2024
0.8.0 Jul 31, 2024
0.7.0 Mar 29, 2024
0.2.0 Jul 26, 2022

#467 in Network programming

Download history 3142/week @ 2024-11-19 1878/week @ 2024-11-26 2275/week @ 2024-12-03 3337/week @ 2024-12-10 1920/week @ 2024-12-17 1100/week @ 2024-12-24 1237/week @ 2024-12-31 4472/week @ 2025-01-07 1369/week @ 2025-01-14 1476/week @ 2025-01-21 3205/week @ 2025-01-28 3057/week @ 2025-02-04 2027/week @ 2025-02-11 1578/week @ 2025-02-18 1689/week @ 2025-02-25 2126/week @ 2025-03-04

7,811 downloads per month
Used in senax

MIT license

16KB
115 lines

axum-aws-lambda

Rust crates.io

This crate provides a tower::Layer that translates hyper/axum requests to the format used by the aws-lambda-rust-runtime crate. This allows users to switch between just running a Hyper server, and running under the Lambda runtime - this dramatically speeds up development! It also means that you can use off-the-shelf components from the Tower ecosystem!

Check out examples/main.rs: running in debug mode runs a hyper server, and building for release mode compiles using the Lambda runtime.

Testing out the Lambda runtime locally

There is an example Dockerfile for locally spinning up a lambda runtime:

cargo build --release --example main
docker build . -t lambda-test
docker run -p 9000:8080 lambda-test

In test-lambda-runtime/ there is a python script for testing and a Dockerfile for running it.

In another shell, from the root of this repository:

cd test-lambda-runtime
docker build . -t test_lambda_runtime
docker run --network="host" test_lambda_runtime

Dependencies

~13–23MB
~389K SLoC