Middy warmup middleware
Warmup middleware for the middy framework, the stylish Node.js middleware engine for AWS Lambda
Warmup middleware that helps to reduce the cold-start issue. Compatible by default with serverless-plugin-warmup
, but it can be configured to suit your implementation.
This middleware allows you to specify a schedule to keep Lambdas that always need to be very responsive warmed-up. It does this by regularly invoking the Lambda, but will terminate early to avoid the actual handler logic from being run.
If you use serverless-plugin-warmup
the scheduling part is done by the plugin and you just have to attach the middleware to your "middyfied" handler. If you don't want to use the plugin you have to create the schedule yourself and define the isWarmingUp
function to define wether the current event is a warmup event or an actual business logic execution.
Install
To install this middleware you can use NPM:
npm install --save @middy/warmup
Options
isWarmingUp
: a function that accepts the event
object as a parameter
and returns true
if the current event is a warmup event and false
if it's a regular execution. The default function will check if the event
object has a source
property set to serverless-plugin-warmup
.onWarmup
: a function that gets executed before the handler exits in case of warmup. By default the function just prints: Exiting early via warmup Middleware
.waitForEmptyEventLoop
: a boolean value (null
by default), that if set will change the current value for context.callbackWaitsForEmptyEventLoop
. In some circumstances it might be useful to force this value to be false
to make sure that the lambda quits as early as possible in case of warmup (for instance if you have created a database connection in a previous middleware, this might be hanging and keeping you lambda active until timeout).
Sample usage
const middy = require('@middy/core')
const warmup = require('@middy/warmup')
const isWarmingUp = (event) => event.isWarmingUp === true
const onWarmup = (event) => console.log('I am just warming up', event)
const originalHandler = (event, context, cb) => {
}
const handler = middy(originalHandler)
.use(warmup({
isWarmingUp,
onWarmup
}))
Middy documentation and examples
For more documentation and examples, refers to the main Middy monorepo on GitHub or Middy official website.
Contributing
Everyone is very welcome to contribute to this repository. Feel free to raise issues or to submit Pull Requests.
License
Licensed under MIT License. Copyright (c) 2017-2018 Luciano Mammino and the Middy team.