cache-throttle
Provides caching and throttling of promises.
- cachify(func, options) - Returns the function wrapped with caching
- cachifyAll(target, options) - Patches all the target's methods with caching
- throttlify(func, options) - Returns the function wrapped with throttling
- throttlifyAll(target, options) - Patches all the target's methods with throttling
These have similar definitions to bluebird's promisify:
You can also use the underlying functions directly:
- throttler.throttleAsync(func) - Limits the number of concurrent calls. Any additional calls will wait.
- lockableCache.callAsync(key, func) - Ensures a function isn't called concurrently. Any subsequent calls with same key before the first has resolved will wait and receive the same response.
Examples
npm install cache-throttle
var cacheThrottle = require('cache-throttle');
var Promise = require('bluebird');
var superagent = require('superagent');
var agent = require('superagent-promise')(superagent, Promise);
var API = {
getUsersAsync: function() {
return agent.get('/users/').end();
},
getDriversAsync: function() {
return agent.get('/drivers/').end();
},
getDriverAsync: function(driverId) {
return agent.get('/drivers/' + driverId).end();
}
};
cacheThrottle.throttlifyAll(API, {
concurrency: 1,
queueLimit: 100,
suffix: 'Throttled',
filter: function(name, func, target, passesDefaultFilter) {
return _.includes(['getUsersAsync', 'getDriversAsync'], name);
}
});
cacheThrottle.cachifyAll(API, {
suffix: 'Cached',
filter: function(name, func, target, passesDefaultFilter) {
return _.includes(['getUsersAsync', 'getDriversAsync'], name);
}
});
Or for single functions:
var getDriversAsyncThrottled = cacheThrottle.throttlify(API.getDriversAsync, {context: API});
var getDriversAsyncCached = cacheThrottle.cachify(API.getDriversAsync, {context: API});
To apply throttlify with the same throttler:
var throttler = new cacheThrottle.Throttler( {
concurrency: 1,
queueLimit: 100
});
var getDriversAsyncThrottled = cacheThrottle.throttlify(API.getDriversAsync, {
context: API,
throttler: throttler
});
var getUsersAsyncThrottled = cacheThrottle.throttlify(API.getUsersAsync, {
context: API,
throttler: throttler
});
cacheThrottle.throttlifyAll(API, {
throttler: throttler,
filter: function(name, func, target, passesDefaultFilter) {
return name === 'getDriverAsync';
}
});
Or use LockableCache
and Throttler
directly:
var throttler = new cacheThrottle.Throttler( {
concurrency: 1,
queueLimit: 100
});
var lockableCache = new cacheThrottle.LockableCache();
lockableCache.callAsync('users', function() {
return throttler.throttleAsync(function() {
return agent.get('/users/').end();
});
});