Giter Site home page Giter Site logo

redback's Introduction

Redback

NPM version Build Status Downloads

A high-level Redis library.

$ npm install redback

Introduction

Redback provides an accessible and extensible interface to the Redis data types and allows you to create your own structures with ease. Redback comes with the following built-in structures: List, Set, SortedSet, Hash, Channel, Cache

It also comes with the following advanced data structures:

  • DensitySet - A sorted set where adding an element increments its score and removing it decrements it
  • KeyPair - Uses two hash structures and an auto-incrementing key to assign an ID to each unique value
  • SocialGraph - Similar to Twitter's (following vs. followers)
  • CappedList - A list with a fixed length
  • Queue - A simple FIFO or LIFO queue
  • RateLimit - Count the number of times an event occurs over an interval. See this introduction.
  • BloomFilter - A probabilistic structure used to test whether an an element exists in a set

Usage

var redback = require('redback').createClient();

// or

var redis = require('redis').createClient();
var redback = require('redback').use(redis);
var user3 = redback.createSocialGraph(3);
user3.follow(1, callback);

var log = redback.createCappedList('log', 1000);
log.push('Log message ...');

var user = redback.createHash('user1');
user.set({username: 'chris', password: 'foobar'}, callback);

Creating your own structures

Use addStructure(name, methods) to create your own structure.

Let's create a queue that can be either FIFO or LIFO:

redback.addStructure('SimpleQueue', {
    init: function (options) {
        options = options || {};
        this.fifo = options.fifo;
    },
    add: function (value, callback) {
        this.client.lpush(this.key, value, callback);
    },
    next: function (callback) {
        var method = this.fifo ? 'rpop' : 'lpop';
        this.client[method](this.key, callback);
    }
});

Call createSimpleQueue(key, options) to use the queue:

var queue = redback.createSimpleQueue('my_queue', {fifo: true});
queue.add('awesome!');

Structures have access to a Redis key this.key and the Redis client this.client. If an init() method is defined then it is called after the structure is instantiated. Also note that init() receives any extra parameters from create<structure>().

Other uses

Cache backend

var cache = redback.createCache(namespace);
cache.set('foo', 'bar', callback);
cache.get('foo', function (err, foo) {
    console.log(foo); //bar
});

Pub/sub provider

var channel = redback.createChannel('chat').subscribe();

//To received messages
channel.on('message', function (msg) {
   console.log(msg);
});

//To send messages
channel.publish(msg);

Documentation

See the annotated source.

Tests

The tests require a local redis instance running on localhost:6379. Note that redis database #11 will be flushed prior to each run.

$ npm test

Credits

  • Matt Ranney for his node_redis library.
  • GitHub user sreeix for the bloom filter implementation.

License

MIT

redback's People

Contributors

aleph2012 avatar bharrisau avatar ceejbot avatar chase avatar chriso avatar mrvisser avatar ncr avatar sreeix avatar srgl avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.