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

एक कतार सेवा के रूप में MongoDB?

मैं ईमेल भेजने के लिए एक कतार सेवा के रूप में मोंगोडब का उपयोग कर रहा हूं। जल्द ही यह निम्नलिखित तरीके से काम करेगा:

  1. जब कोई नया संदेश आता है तो मैं उसे मोंगोडब में संग्रहीत करता हूं।
  2. एक बैकग्राउंड जॉब फिर परमाणु ऑपरेशन के माध्यम से मोंगोडब से संदेश को लोड करता है findAndModify और फ्लैग सेट करता है Processing सच है, इसलिए यह एक ही संदेश को दो बार संसाधित नहीं करता है (क्योंकि मेरा बैकग्राउंड जॉब समानांतर में कई थ्रेड चलाता है)।
  3. एक बार ईमेल भेजे जाने के बाद मैं दस्तावेज़ को mongodb से हटा देता हूँ।
  4. आप प्रत्येक संदेश के लिए विफलताओं की गिनती भी रख सकते हैं और 3 विफल प्रयासों के बाद इसे हटा सकते हैं।

आम तौर पर मैं केवल एक कारण के लिए कतार सेवा के रूप में mongodb का उपयोग करता हूं:क्योंकि मुझे निर्दिष्ट समय-सारणी द्वारा ईमेल भेजने की आवश्यकता होती है (प्रत्येक संदेश में यह जानकारी होती है कि इसे किस समय भेजा जाना चाहिए)।

यदि आपके पास कोई शेड्यूल नहीं है और संदेश को तुरंत संसाधित करने की आवश्यकता है, तो मेरा सुझाव है कि आप मौजूदा कतार सेवाओं को देखें, क्योंकि वे संभवतः उन सभी मामलों को संभालती हैं जिन्हें आप संदेश कतारों की गहरी समझ के बिना नहीं देख सकते हैं।

अपडेट करें

जब मैसेज प्रोसेसिंग के दौरान बैकग्राउंड जॉब क्रैश हो जाता है तो आप निम्न कार्य कर सकते हैं:

  1. इस संदेश को दूसरे में ले जाएं, संदेश कतार त्रुटि संग्रह या ..

  2. एक संदेश में प्रसंस्करण प्रयास काउंटर बढ़ाएँ और इसे फिर से संसाधित करने का प्रयास करने के लिए "नया" स्थिति निर्दिष्ट करें। बस यह सुनिश्चित करें कि बैकग्राउंड जॉब बेकार है (एक ही संदेश को कई बार प्रोसेस कर सकता है और डेटा को दूषित नहीं कर सकता) और ट्रांजेक्शनल (जब जॉब फेल हो जाता है तो आपको किए गए परिवर्तनों को पूर्ववत करना होगा। यदि कोई हो)। जब 5 प्रयासों के बाद नौकरी विफल हो जाती है (कॉन्फ़िगरेशन मान) # 1 प्रदर्शन करें।

  3. एक बार संदेश प्रसंस्करण के साथ बग ठीक हो जाने के बाद आप "नई" स्थिति निर्दिष्ट करके और संदेश कतार में जाकर इसे फिर से संसाधित कर सकते हैं, या बस इस संदेश को हटा सकते हैं। यह वास्तव में व्यावसायिक प्रक्रियाओं पर निर्भर करता है।



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. उल्का:क्लाइंट से मोंगो संग्रह बनाम फाइल सिस्टम बनाम ग्रिडएफएस में फाइल अपलोड करना

  2. फ़ाइल आयात करके MongoDB दस्तावेज़ कैसे हटाएं

  3. ओवरफ़्लो सॉर्ट चरण बफ़र किए गए डेटा का उपयोग आंतरिक सीमा से अधिक है

  4. मैं मोंगोडब पर केस-असंवेदनशील प्रश्न कैसे बना सकता हूं?

  5. मोंगोडीबी के लिए रैम में वर्किंग सेट फिट करने का क्या मतलब है?