0.7.0 • Published 7 years ago

cnn-caching v0.7.0

Weekly downloads
7
License
MIT
Repository
github
Last release
7 years ago

CNN Caching

Makes working with caching easier. Now with hash ring support!

Fork of mape/node-caching

build node npm npm-downloads dependency-status

Installation

Via npm:

$ npm install cnn-caching

Built in stores

  • Memory
  • Redis
  • Hash Ring

Pseudo-code Example

var Caching = require('cnn-caching');
var cache = new Caching('redis'); /* use 'memory', 'redis' or 'hashring' */

var ttl = 60 * 1000; // 1minute;
cache('twitter-users', ttl, function(passalong) {
    getMostActiveTwitterUser(function(err, userName) {
        fetchTwitterFollowers(userName, passalong); // passalong replaces function(err, userList) {}
    })
}, function(err, userList) {
    console.log(userList);
});

Memory Code Example

var Caching = require('cnn-caching');
var cache = new Caching();

setInterval(function() {
    cache('key', 10000 /*ttl in ms*/, function(passalong) {
        // This will only run once, all following requests will use cached data.
        setTimeout(function() {
            passalong(null, 'Cached result');
        }, 1000);
    }, function(err, results) {
        // This callback will be reused each call
        console.log(results);
    });
}, 100);

Redis Code Example

var Caching = require('cnn-caching');
var cache = new Caching('redis');

setInterval(function() {
    cache('key', 10000 /*ttl in ms*/, function(passalong) {
        // This will only run once, all following requests will use cached data.
        setTimeout(function() {
            passalong(null, 'Cached result');
        }, 1000);
    }, function(err, results) {
        // This callback will be reused each call
        console.log(results);
    });
}, 100);

Hash Ring Code Example

var Caching = require('cnn-caching');
var cache = new Caching('hashring', {
        "servers": 'http://localhost:6377,http://localhost:6378,http://localhost:6379,http://localhost:6380',
        "max cache size": 10000,  /* Any node-hashing options allowed */
        "minTtl": 10  /* Minimum TTL that cnn-caching will actually cache (default 0) */
    });

setInterval(function() {
    cache('key', 10000 /*ttl in ms*/, function(passalong) {
        // This will only run once, all following requests will use cached data.
        setTimeout(function() {
            passalong(null, 'Cached result');
        }, 1000);
    }, function(err, results) {
        // This callback will be reused each call
        console.log(results);
    });
}, 100);

Api

cache(key, ttl, runIfNothingInCache, useReturnedCachedResults);

arguments0

Key, 'myKey'

arguments1

Time To Live in ms, 60*30*1000

arguments2

Callback that will run if results aren't already in cache store.

function (passalong) {
    setTimeout(function() {
        passalong(null, 'mape', 'frontend developer', 'sweden');
    }, 1000);
}

arguments3

Callback that is called every time the method runs.

function(err, result) {
    console.log(name, result);
}
0.7.0

7 years ago

0.6.4

8 years ago

0.6.3

8 years ago

0.6.2

8 years ago

0.6.1

8 years ago

0.6.0

8 years ago

0.5.0

8 years ago