forked from zhurui/management
56 lines
1.1 KiB
Markdown
56 lines
1.1 KiB
Markdown
killable
|
|
========
|
|
|
|
Keeps track of a server's open sockets so they can be destroyed at a
|
|
moment's notice. This way, the server connection can be killed very
|
|
fast.
|
|
|
|
Installation
|
|
------------
|
|
|
|
```
|
|
npm install killable
|
|
```
|
|
|
|
Example usage
|
|
-------------
|
|
|
|
Using express:
|
|
('server' in the example is just an ``http.server``, so other frameworks
|
|
or pure Node should work just as well.)
|
|
|
|
```javascript
|
|
var killable = require('killable');
|
|
|
|
var app = require('express')();
|
|
var server;
|
|
|
|
app.route('/', function (req, res, next) {
|
|
res.send('Server is going down NOW!');
|
|
|
|
server.kill(function () {
|
|
//the server is down when this is called. That won't take long.
|
|
});
|
|
});
|
|
|
|
var server = app.listen(8080);
|
|
killable(server);
|
|
```
|
|
|
|
API
|
|
---
|
|
|
|
The ``killable`` module is callable. When you call it on a Node
|
|
``http.Server`` object, it will add a ``server.kill()`` method on it. It
|
|
returns the server object.
|
|
|
|
``server.kill([callback])`` closes all open sockets and calls
|
|
``server.close()``, to which the ``callback`` is passed on.
|
|
|
|
Inspired by: http://stackoverflow.com/a/14636625
|
|
|
|
License
|
|
-------
|
|
|
|
ISC
|