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

मुझे अपने संकुल नोड में डुप्लिकेट संदेश प्राप्त हो रहे हैं।js/socket.io/redis pub/sub application

मैं क्लस्टर और सॉकेट से जूझ रहा हूं। हर बार जब मैं क्लस्टर फ़ंक्शन का उपयोग करता हूं (हालांकि मैं बिल्ट इन नोडज क्लस्टर का उपयोग करता हूं) मुझे सॉकेट के साथ प्रदर्शन समस्याओं और मुद्दों का एक बहुत कुछ मिलता है।

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

ऐसा लगता है कि समस्या "क्लाइंट हैंडशेक क्लाइंट को फिर से कनेक्ट नहीं करना चाहिए" जो आप देखेंगे कि क्या आप वर्बोज़ लॉगिंग बढ़ाते हैं। जब भी socket.io क्लस्टर में चलता है तो यह बहुत दिखाई देता है, इसलिए मुझे लगता है कि यह इस पर वापस आ जाता है। यानी क्लाइंट हर बार एक नया कनेक्शन करने पर socket.io क्लस्टर में यादृच्छिक उदाहरण से जुड़ जाता है (यह अधिकृत करते समय कई http/socket/flash कनेक्शन करता है और नए डेटा के लिए मतदान करते समय हर समय अधिक होता है)।

अभी के लिए मैं एक बार में केवल 1 socket.io प्रक्रिया का उपयोग करने के लिए वापस लौट आया हूं, यह एक बग हो सकता है लेकिन यह भी एक कमी हो सकती है कि कैसे socket.io बनाया गया है।

जोड़ा गया:भविष्य में इसे हल करने का मेरा तरीका क्लस्टर के अंदर प्रत्येक सॉकेट.आईओ इंस्टेंस के लिए एक अद्वितीय पोर्ट असाइन करना और फिर क्लाइंट साइड पर कैश पोर्ट चयन करना होगा।



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. रेल 4, प्यूमा और साइडकीक के साथ रेडिस कनेक्शन कैसे कॉन्फ़िगर करें?

  2. रेडिस में डेटा निर्देशिका कहाँ है?

  3. कैशे_स्टोर को इनिशियलाइज़र में सेट करना

  4. फ्लशडीबी रेडिस में सभी चाबियाँ साफ़ नहीं करता है?

  5. सर्वर साइड पर JSON ऑब्जेक्ट्स को कैशिंग करना