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

नोड.जेएस + रेडिस के साथ उपयोगकर्ता और सॉकेट जोड़े को कैसे संभालें?

प्रत्येक सॉकेट को चैनल उपयोगकर्ता आईडी से कनेक्ट करने के लिए एक अधिक सुरुचिपूर्ण समाधान होगा, उदाहरण के लिए:

io.sockets.on('connection', function (socket) {
  socket.join(userID);
});

// when you want somebody to send a message to userID you can do:
io.sockets.in(userID).emit(message);

यहां आपको दो बातों का ध्यान रखना होगा:

  1. सुनिश्चित करें कि केवल userID ही उसके चैनल से जुड़ सकता है, इस प्रकार सत्र को सत्यापित करें (यहां और पढ़ें:http://www.danielbaulig.de/socket-ioexpress/)
  2. कनेक्शन पर redis में userID के लिए मान बढ़ाएं (ताकि आप जान सकें कि उस उपयोगकर्ता के लिए एक नया कनेक्शन सुन रहा है) और डिस्कनेक्ट करने पर userID मान कम करें (ताकि आप अभी भी सुन रहे कनेक्शन की संख्या जान सकें)। यदि मान 0 है तो आप चैट में एक संदेश भेजते हैं जिसमें कहा गया है कि उपयोगकर्ता आईडी छोड़ दिया है (चूंकि उपयोगकर्ता आईडी चैनल को सुनने वाले कनेक्शन की संख्या 0 है)।

जब अन्य उपयोगकर्ता उपयोगकर्ता आईडी को संदेश भेजना चाहते हैं, तो उन्हें उपयोगकर्ता आईडी चैनल से कनेक्ट करने की आवश्यकता नहीं होती है, वे chat पर एक संदेश भेज सकते हैं चैनल और उपयोगकर्ता आईडी को एक संपत्ति के रूप में पास करें। उदाहरण के लिए:

var chat = io
  .of('/chat')
  .on('connection', function (socket) {
    // connected to public chat
  })
  .on('message', function (data) {
    if (data.userID && data.message) {
      io.sockets.in(userID).emit('UserX: ' + data.message);
    }
  });



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Redis/Jedis विफलता और स्वचालित विफलता का एक भी बिंदु नहीं है

  2. एचएसईटी यदि कुंजी मौजूद है

  3. Redis . में एकाधिक कुंजियों का नाम कैसे बदलें

  4. रेडिस इंस्टाल सीसी के साथ समस्या:कमांड नहीं मिली

  5. Django Celery कार्य के अंदर db पोस्टग्रेज को क्वेरी नहीं कर सकता है