whooohoo jackpot
Jackpot is a fault tolerant connection pool for Node.js, it automatically cleans
up after it self and detects broken connections. It does not need to be
released, as it will allocate connections based on their readyState / write
abilities.
API
var ConnectionPool = require('jackpot');
var pool = new ConnectionPool(100);
The following options can be configured:
retries
the amount of retries the pull method should do.factor
exponential backoff factor.min
minimal delay for the backoff.max
maximum delay for the backoff.randomize
randomize the connection.
var pool = new ConnectionPool(100, {
min: 100
max: 50000
});
But you can also set the properties:
pool.retries = 5
You can set the required factory at the contructor but also through a helper
method:
pool.factory(function () {
return net.connect(port, host)
});
There are 2 ways to retrieve a connection, using allocate
:
``js`
// now that the pool is setup we can allocate a connection, the allocate
// requires a callback as it can be async..
pool.allocate(function (err, connection) {
// error: when we failed to get a connection
// connection: the allocated net.connection if there isn't an error
});
And `pull`;
```js
// in addition to the #allocate method, there is also the pull method, which is
// fault tolerant wrapper around the allocate function as it can give back an
// error if the pool is full, so the pull will then retry to get a new
connection.pull(function (err, connection) {
// same arguments as the #allocate method
});
And some misc methods:
pool.free(10);
pool.end();
For more API information, fork this repo and add more.. or look at the test
file.
LICENSE (MIT)
Copyright (c) 2013 Observe.it (http://observe.it) opensource@observe.it
Permission is hereby granted, free of charge, to any person obtaining a copy of
this software and associated documentation files (the "Software"), to deal in
the Software without restriction, including without limitation the rights to
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.