AWS Lambda Web Adapter

March 27, 2026 ยท View on GitHub

A tool to run web applications on AWS Lambda

AWS Lambda Web Adapter allows developers to build web apps (http api) with familiar frameworks (e.g. Express.js, Next.js, Flask, SpringBoot, ASP.NET and Laravel, anything speaks HTTP 1.1/1.0) and run it on AWS Lambda. The same docker image can run on AWS Lambda, Amazon EC2, AWS Fargate, and local computers.

Lambda Web Adapter

๐Ÿ“– Read the full User Guide

Features

  • Run web applications on AWS Lambda
  • Supports Amazon API Gateway Rest API and Http API endpoints, Lambda Function URLs, and Application Load Balancer
  • Supports Lambda managed runtimes, custom runtimes and docker OCI images
  • Supports Lambda Managed Instances for multi-concurrent request handling
  • Supports any web frameworks and languages, no new code dependency to include
  • Automatic encode binary response
  • Enables graceful shutdown
  • Supports response payload compression
  • Supports response streaming
  • Supports multi-tenancy via tenant ID propagation
  • Supports non-http event triggers

Quick Start

Docker Images

Add one line to your Dockerfile:

COPY --from=public.ecr.aws/awsguru/aws-lambda-adapter:1.0.0 /lambda-adapter /opt/extensions/lambda-adapter

Pre-compiled multi-arch images (x86_64 and arm64) are available at public.ecr.aws/awsguru/aws-lambda-adapter. Non-AWS base images may be used since the Runtime Interface Client ships with the Lambda Web Adapter.

๐Ÿ‘‰ Docker Images guide

Zip Packages

  1. Attach the Lambda Web Adapter layer to your function:
    • x86_64: arn:aws:lambda:${AWS::Region}:753240598075:layer:LambdaAdapterLayerX86:27
    • arm64: arn:aws:lambda:${AWS::Region}:753240598075:layer:LambdaAdapterLayerArm64:27
  2. Set environment variable AWS_LAMBDA_EXEC_WRAPPER to /opt/bootstrap
  3. Set function handler to your startup script, e.g. run.sh

๐Ÿ‘‰ Zip Packages guide (includes AWS China region ARNs and Windows caveats)

Configurations

The readiness check port/path and traffic port can be configured using environment variables. These environment variables can be defined either within docker file or as Lambda function configuration.

Environment VariableDescriptionDefault
AWS_LWA_PORTtraffic port (falls back to PORT)"8080"
AWS_LWA_READINESS_CHECK_PORTreadiness check portAWS_LWA_PORT
AWS_LWA_READINESS_CHECK_PATHreadiness check path"/"
AWS_LWA_READINESS_CHECK_PROTOCOLreadiness check protocol: "http" or "tcp""http"
AWS_LWA_READINESS_CHECK_HEALTHY_STATUSHTTP status codes considered healthy (e.g., "200-399")"100-499"
AWS_LWA_ASYNC_INITenable asynchronous initialization for long initialization functions"false"
AWS_LWA_REMOVE_BASE_PATHthe base path to be removed from request pathNone
AWS_LWA_ENABLE_COMPRESSIONenable gzip/br compression for response body (buffered mode only)"false"
AWS_LWA_INVOKE_MODELambda function invoke mode: "buffered" or "response_stream""buffered"
AWS_LWA_PASS_THROUGH_PATHthe path for receiving event payloads from non-http triggers"/events"
AWS_LWA_AUTHORIZATION_SOURCEa header name to be replaced to AuthorizationNone
AWS_LWA_ERROR_STATUS_CODESHTTP status codes that will cause Lambda invocations to fail (e.g. "500,502-504")None
AWS_LWA_LAMBDA_RUNTIME_API_PROXYoverwrites AWS_LAMBDA_RUNTIME_API to allow proxying requestNone

Deprecation Notice: The following non-namespaced environment variables are deprecated and will be removed in version 2.0: HOST, READINESS_CHECK_PORT, READINESS_CHECK_PATH, READINESS_CHECK_PROTOCOL, REMOVE_BASE_PATH, ASYNC_INIT. Please migrate to the AWS_LWA_ prefixed versions. Note: PORT is not deprecated and remains a supported fallback for AWS_LWA_PORT.

Additionally, AWS_LWA_READINESS_CHECK_MIN_UNHEALTHY_STATUS has been removed in 1.0. Use AWS_LWA_READINESS_CHECK_HEALTHY_STATUS instead.

๐Ÿ‘‰ Detailed configuration docs

Examples

๐Ÿ‘‰ Examples organized by language

Acknowledgement

This project was inspired by several community projects.

Migrating from 0.x to 1.0

Environment Variables

All environment variables now use the AWS_LWA_ prefix. The old non-prefixed names still work but are deprecated and will be removed in version 2.0.

Old (Deprecated)New
READINESS_CHECK_PORTAWS_LWA_READINESS_CHECK_PORT
READINESS_CHECK_PATHAWS_LWA_READINESS_CHECK_PATH
READINESS_CHECK_PROTOCOLAWS_LWA_READINESS_CHECK_PROTOCOL
REMOVE_BASE_PATHAWS_LWA_REMOVE_BASE_PATH
ASYNC_INITAWS_LWA_ASYNC_INIT

Note: PORT is not deprecated and remains a supported fallback for AWS_LWA_PORT.

Readiness Check Health Status

AWS_LWA_READINESS_CHECK_MIN_UNHEALTHY_STATUS has been removed. Use AWS_LWA_READINESS_CHECK_HEALTHY_STATUS instead, which accepts comma-separated codes and ranges:

# Old
AWS_LWA_READINESS_CHECK_MIN_UNHEALTHY_STATUS=400

# New (equivalent)
AWS_LWA_READINESS_CHECK_HEALTHY_STATUS=100-399

Similar Projects

Several projects also provide similar capabilities as language specific packages/frameworks.

Security

See SECURITY for vulnerability reporting and CONTRIBUTING for more information.

License

This project is licensed under the Apache-2.0 License.