You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
77 lines
2.1 KiB
77 lines
2.1 KiB
var cashew = require('cashew');
|
|
var redis_cache = cashew.caching({store: 'redis', db: 1, ttl: 100/*seconds*/});
|
|
var memory_cache = cashew.caching({store: 'memory', max: 100, ttl: 10/*seconds*/});
|
|
|
|
redis_cache.set('foo', 'bar', function(err) {
|
|
if (err) { throw err; }
|
|
|
|
redis_cache.get('foo', function(err, result) {
|
|
console.log(result);
|
|
// >> 'bar'
|
|
redis_cache.del('foo', function(err) {});
|
|
});
|
|
});
|
|
|
|
function get_user(id, cb) {
|
|
setTimeout(function () {
|
|
console.log("Returning user from slow database.");
|
|
cb(null, {id: id, name: 'Bob'});
|
|
}, 100);
|
|
}
|
|
|
|
var user_id = 123;
|
|
var key = 'user_' + user_id;
|
|
|
|
redis_cache.wrap(key, function (cb) {
|
|
get_user(user_id, cb);
|
|
}, function (err, user) {
|
|
console.log(user);
|
|
|
|
// Second time fetches user from redis_cache
|
|
redis_cache.wrap(key, function (cb) {
|
|
get_user(user_id, cb);
|
|
}, function (err, user) {
|
|
console.log(user);
|
|
});
|
|
});
|
|
|
|
// Outputs:
|
|
// Returning user from slow database.
|
|
// { id: 123, name: 'Bob' }
|
|
// { id: 123, name: 'Bob' }
|
|
|
|
|
|
var multi_cache = cashew.multi_caching([memory_cache, redis_cache]);
|
|
user_id2 = 456;
|
|
key2 = 'user_' + user_id;
|
|
|
|
multi_cache.wrap(key2, function (cb) {
|
|
get_user(user_id2, cb);
|
|
}, function (err, user) {
|
|
console.log(user);
|
|
|
|
// Second time fetches user from memory_cache, since it's highest priority.
|
|
// If the data expires in the memory cache, the next fetch would pull it from
|
|
// the Redis cache, and set the data in memory again.
|
|
multi_cache.wrap(key2, function (cb) {
|
|
get_user(user_id2, cb);
|
|
}, function (err, user) {
|
|
console.log(user);
|
|
});
|
|
|
|
// Sets in all caches.
|
|
multi_cache.set('foo2', 'bar2', function(err) {
|
|
if (err) { throw err; }
|
|
|
|
// Fetches from highest priority cache that has the key.
|
|
multi_cache.get('foo2', function(err, result) {
|
|
console.log(result);
|
|
// >> 'bar2'
|
|
|
|
// Delete from all caches
|
|
multi_cache.del('foo2', function(err) {
|
|
process.exit();
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|