GitXplorerGitXplorer
o

wrr-pool

public
6 stars
3 forks
1 issues

Commits

List of commits on branch master.
Unverified
451b62883ae3b3a9a5b621f6ccf8eda5ce2b312e

1.1.4

committed 6 years ago
Unverified
e90aa67c71e9769d3ae25ad442384ab8200c2e9d

Update lodash

committed 6 years ago
Unverified
5c3932a82d027cb65763f0cbb875a0ac687331e2

Drop Node 0.10, Add Node 8.12

ooleksiyk committed 6 years ago
Unverified
5db1d95bc23466773e2fa3215cf2abb5bf0c3939

Use eslint-magictoolbox

ooleksiyk committed 9 years ago
Unverified
3e626f90fce6b3d109579ea0eba08eb00fdfd792

Update eslint and eslint-airbnb

ooleksiyk committed 9 years ago
Unverified
675fd273d37e5819b9ec3bac4301b42695982099

Update Node LTS to 4.3 branch

ooleksiyk committed 9 years ago

README

The README file for this repository.

Build Status Test Coverage Dependencies DevDependencies

WRRPool

WRRPool is a Weighted Round Robin resource pool

Using

npm install wrr-pool

Basic usage

var WRRPool = require('wrr-pool');

var pool = new WRRPool();

pool.add('A', 4); // pool.add({ host: '10.0.1.10', port: 8087}, 4)
pool.add('B', 3); // pool.add({ host: '10.0.1.11', port: 8087}, 3)
pool.add('C', 2); // pool.add({ host: '10.0.1.12', port: 8087}, 2)

pool.next(); // A
pool.next(); // A
pool.next(); // B
pool.next(); // A
pool.next(); // B
pool.next(); // C
pool.next(); // A
pool.next(); // B
pool.next(); // C

Get resource and its weight

var pool = new WRRPool();

pool.add({ id: 1 }, 4);
pool.add({ id: 2 }, 3);
pool.add({ id: 3 }, 2);

pool.get({ id: 2 }); // => { value: { id: 2 }, weight: 3 }
var pool = new WRRPool();

pool.add({ id: 1 }, 4);
pool.add({ id: 2 }, 3);
pool.add({ id: 3 }, 2);

pool.get(function (v){ return v.id === 2; }); // => { value: { id: 2 }, weight: 3 }

Update resource value and/or weight

var pool = new WRRPool();

pool.add('A', 4);
pool.add('B', 3);
pool.add('C', 2);

// update value to 'B1' and weight to 4
pool.update(function (v) { return v === 'B';}, 'B1', 4); // => returns index of updated element or undefined if not found

Remove resource from pool

var pool = new WRRPool();

pool.add('A', 4);
pool.add('B', 3);
pool.add('C', 2);

pool.remove(function (v) { return v === 'C';});  // => returns index of removed element or undefined if not found

License

MIT