Redis
 sql >> डेटाबेस >  >> NoSQL >> Redis

Node.js, Socket.io, Redis पब/उप उच्च मात्रा, कम विलंबता कठिनाइयाँ

मैंने सोचा कि यह एक उचित प्रश्न था और कुछ समय पहले इस पर संक्षेप में शोध किया था। मैंने उन उदाहरणों की खोज में थोड़ा समय बिताया, जिनसे आप कुछ उपयोगी टिप्स लेने में सक्षम हो सकते हैं।

उदाहरण

मुझे सीधे आगे के उदाहरणों के साथ शुरुआत करना पसंद है:

  • प्रकाश im नमूना कोड
  • Node.js + Redis Pub/Sub + socket.io डेमो

प्रकाश का नमूना एक एकल पृष्ठ है (ध्यान दें कि आप मैट रैनी द्वारा रेडिस-नोड-क्लाइंट को नोड_रेडिस जैसी किसी चीज़ से बदलना चाहेंगे:

/*
 * Mclarens Bar: Redis based Instant Messaging
 * Nikhil Marathe - 22/04/2010

 * A simple example of an IM client implemented using
 * Redis PUB/SUB commands so that all the communication
 * is offloaded to Redis, and the node.js code only
 * handles command interpretation,presentation and subscribing.
 * 
 * Requires redis-node-client and a recent version of Redis
 *    http://code.google.com/p/redis
 *    http://github.com/fictorial/redis-node-client
 *
 * Start the server then telnet to port 8000
 * Register with NICK <nick>, use WHO to see others
 * Use TALKTO <nick> to initiate a chat. Send a message
 * using MSG <nick> <msg>. Note its important to do a
 * TALKTO so that both sides are listening. Use STOP <nick>
 * to stop talking to someone, and QUIT to exit.
 *
 * This code is in the public domain.
 */
var redis = require('./redis-node-client/lib/redis-client');

var sys = require('sys');
var net = require('net');

var server = net.createServer(function(stream) {
    var sub; // redis connection
    var pub;
    var registered = false;
    var nick = "";

    function channel(a,b) {
    return [a,b].sort().join(':');
    }

    function shareTable(other) {
    sys.debug(nick + ": Subscribing to "+channel(nick,other));
    sub.subscribeTo(channel(nick,other), function(channel, message) {
        var str = message.toString();
        var sender = str.slice(0, str.indexOf(':'));
        if( sender != nick )
        stream.write("[" + sender + "] " + str.substr(str.indexOf(':')+1) + "\n");
    });
    }

    function leaveTable(other) {
    sub.unsubscribeFrom(channel(nick,other), function(err) {
        stream.write("Stopped talking to " + other+ "\n");
    });
    }

    stream.addListener("connect", function() {
    sub = redis.createClient();
    pub = redis.createClient();
    });

    stream.addListener("data", function(data) {
    if( !registered ) {
        var msg = data.toString().match(/^NICK (\w*)/);
        if(msg) {
        stream.write("SERVER: Hi " + msg[1] + "\n");
        pub.sadd('mclarens:inside', msg[1], function(err) {
            if(err) {
            stream.end();
            }
            registered = true;
            nick = msg[1];
// server messages
            sub.subscribeTo( nick + ":info", function(nick, message) {
            var m = message.toString().split(' ');
            var cmd = m[0];
            var who = m[1];
            if( cmd == "start" ) {
                stream.write( who + " is now talking to you\n");
                shareTable(who);
            }
            else if( cmd == "stop" ) {
                stream.write( who + " stopped talking to you\n");
                leaveTable(who);
            }
            });
        });
        }
        else {
        stream.write("Please register with NICK <nickname>\n");
        }
        return;
    }

    var fragments = data.toString().replace('\r\n', '').split(' ');
    switch(fragments[0]) {
    case 'TALKTO':
        pub.publish(fragments[1]+":info", "start " + nick, function(a,b) {
        });
        shareTable(fragments[1]);
        break;
    case 'MSG':
        pub.publish(channel(nick, fragments[1]),
            nick + ':' +fragments.slice(2).join(' '),
              function(err, reply) {
              if(err) {
                  stream.write("ERROR!");
              }
              });
        break;
    case 'WHO':
        pub.smembers('mclarens:inside', function(err, users) {
        stream.write("Online:\n" + users.join('\n') + "\n");
        });
        break;
    case 'STOP':
        leaveTable(fragments[1]);
        pub.publish(fragments[1]+":info", "stop " + nick, function() {});
        break;
    case 'QUIT':
        stream.end();
        break;
    }
    });

    stream.addListener("end", function() {
    pub.publish(nick, nick + " is offline");
    pub.srem('mclarens:inside', nick, function(err) {
        if(err) {
        sys.debug("Could not remove client");
        }
    });
    });
});

server.listen(8000, "localhost");

दस्तावेज़

वहाँ बहुत सारे दस्तावेज हैं, और इस प्रकार के ढेर पर एपिस तेजी से बदल रहे हैं, इसलिए आपको प्रत्येक दस्तावेज़ की प्रासंगिकता को तौलना होगा।

  • नोड गतिविधि स्ट्रीम
  • क्लाउड फाउंड्री उदाहरण
  • रेडिस पबसुब को नोड कैसे करें
  • रेडिस लेटेंसी
  • अतुल्यकालिक संचार के लिए पब/उप का उपयोग कर रेडिस कुकबुक
  • लिंक्डिन की सामान्य युक्तियाँ
  • नोड रेडिस बाइंडिंग
  • गूगल समूह नोडज प्रश्न

संबंधित प्रश्न

बस कुछ संबंधित प्रश्न, यह स्टैक पर एक गर्म विषय है:

  • नोड.जेएस में चैट सर्वर के लिए रेडिस पब/उप
  • एक त्वरित संदेश प्रणाली के लिए रेडिस पब/उप कैसे डिज़ाइन करें?

उल्लेखनीय टिप्स (ymmv)

सॉकेट पूलिंग को बंद या अनुकूलित करें, कुशल बाइंडिंग का उपयोग करें, विलंबता की निगरानी करें, और सुनिश्चित करें कि आप काम की नकल नहीं कर रहे हैं (यानी सभी श्रोताओं को दो बार प्रकाशित करने की आवश्यकता नहीं है)।




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. केरस भविष्यवाणी करते हैं कि अजवाइन कार्य के अंदर नहीं लौटेंगे

  2. रेस्क्यू और रेल के साथ रेडिस:उपयोग की जाने वाली मेमोरी> 'मैक्समेमरी' के दौरान ईआरआर कमांड की अनुमति नहीं है

  3. रेडिस सेट का उपयोग करना

  4. कैसे एडब्ल्यूएस ElastiCache पर स्मृति विश्लेषण चलाने के लिए?

  5. क्या एकाधिक क्लाइंट रेडिस में अवरुद्ध किए बिना एक ही सूची को एक साथ एक्सेस कर सकते हैं?