Skip to content

The super-graceful-shutdown npm package provides a super graceful way to shutdown an Express server application.

License

Notifications You must be signed in to change notification settings

jeanniton-mnr/super-graceful-shutdown

Repository files navigation

Description

The super-graceful-shutdown npm package provides a super graceful way to shutdown an Express server application.

super-graceful-shutdown always make sure a response is sent to the client for any connections that were open before you send a super graceful "shutdown" message.

When you send the default shutdown message on default port 3000 to your node the Express app, super-graceful-shutdown will gracefully wait for all requests to close, ensuring a response is sent to the client; block any new connections; shutdown the server; then terminate node process.

Usage

To use the super-graceful-shutdown package, follow these steps:

  1. Import the package and initialize it using its constructor with an instance of your Express app and server:
const express = require('express');
const SGS = require('super-graceful-shutdown');

const app = express();
const router = express.Router();
const port = 80; // Set your desired port number

// ...

router.get('/api1', async function(req, res, next){
  try {
      setTimeout(() => { res.status(200).send(`<html> <body> <h1>${date()}</h1> </body> </html>`)  }, 3000);
    } catch (error) {
      next(error);
    }
});

const server = app.listen(port, () => console.log(`Example Express app listening on port ${port}!`) );

// ℹ️ Before you initialize other routes, you need to initialize super-graceful-shutdown
new SGS(app, server);

// ℹ️ By default, super-graceful-shutdown will send the SIGTERM to the node process.
// ℹ️ However, you can also manually exit the app once all active connections are closed.
// ℹ️ new SGS(app, server, () => process.exit(0));

// 👨‍💻 Then, you can initialize other routes
app.use('/', router);
  1. Once your Express app is running, to super gracefully shutdown your Node.Js Express application through your host CLI, run this command:
echo "shutdown" | nc localhost 3000

Notes

Do not expose port 3000 to prevent outsiders from shutting down your application. You can find an article on how to allow or block a port to the outside network in this link provided by DigitalOcean.

Reference:

I have this npm package boilerplate to create this package.

Author

Monero Jeanniton

About

The super-graceful-shutdown npm package provides a super graceful way to shutdown an Express server application.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published