A component in having zero downtime deploys for Node.js with Express. It was developed for Express 3.X, so it may need work to be compatible with Express 2.X
This module was developed for Frafty, a Daily Fantasy Sports site.
$ cd /path/to/your/project
$ npm install express-graceful-exit
The following two components must be setup for this to work as planned.
This middleware should be the very first middleware that gets setup with your Express app.
var express = require('express')
, app = express()
, gracefulExit = require('express-graceful-exit')
app.use(gracefulExit.middleware(app))
This function will cleanup the server and get it ready for shutting down. It can be attached to a signal, or used as a normal function call if another tool is used (such as naught).
// Example for naught
process.on('message', function(message) {
if (message === 'shutdown') {
gracefulExit.gracefulExitHandler(app, server {
socketio: app.settings.socketio
})
}
})
There are no options available currently.
The following options are available:
- log: Shows some messages about what is going on (default false).
- logger: Function that accepts a string to output a log message (default console.log).
- suicideTimeout: The timeout to forcefully exit the process with a return code of 1 (default 3 minutes).
- socketio: An instance of socket.io, that will close all open socket.io connections (default none)
- force: Instructs the module to forcibly close sockets once the suicide timeout elapses. Requires that gracefulExit.init(server) be called when initializing the HTTP server (default: false)
- exitProcess: Instructs this module to call process.exit it is done (default true).
- callback: Function that will be called with the "exit" status code once closing express is done (for good or worse). Should be use in conjunction with exitProcess=false, where it is the responsilbity of the caller to handle process shutdown.
To gracefully exit this module will do the following things:
- Close the server so no new connections get accepted
- Mark that the server will gracefully exit, so if a connection that is using the Keep-Alive header is still active, it will be told to close the connection. The HTTP status code of 502 is returned, so nginx, ELB, etc will try again with a working server.
- If a socket.io instance is passed in the options, it enumerates all connected clients and disconnects them. The client should have code to reconnect on disconnect.
- Once all connected clients are disconnected, the server exits with an error code of 0.
- If there are still some remaining connections after the
suicideTimeout
, the server ungracefully exits with an error code of 1.
This module does not give you zero downtime deploys automatically, but provides a server that is capable of exiting gracefully, which can then be used by a module like naught to provide zero downtime deploys.