कैसेंड्रा - वास्तुकला

कैसेंड्रा का डिज़ाइन लक्ष्य किसी भी एकल बिंदु विफलता के बिना कई नोड्स में बड़े डेटा वर्कलोड को संभालना है। कैसेंड्रा के पास अपने नोड्स में सहकर्मी से सहकर्मी वितरित प्रणाली है, और डेटा एक क्लस्टर में सभी नोड्स के बीच वितरित किया जाता है।

  • एक क्लस्टर में सभी नोड्स एक ही भूमिका निभाते हैं। प्रत्येक नोड स्वतंत्र है और एक ही समय में अन्य नोड्स से जुड़ा हुआ है।

  • क्लस्टर में प्रत्येक नोड अनुरोध को पढ़ना और लिखना स्वीकार कर सकता है, भले ही डेटा वास्तव में क्लस्टर में स्थित हो।

  • जब एक नोड नीचे जाता है, तो नेटवर्क में अन्य नोड्स से पढ़ने / लिखने के अनुरोधों को परोसा जा सकता है।

कैसंड्रा में डेटा प्रतिकृति

कैसंड्रा में, क्लस्टर के एक या अधिक नोड डेटा के दिए गए टुकड़े के लिए प्रतिकृतियां के रूप में कार्य करते हैं। यदि यह पता चला है कि कुछ नोड्स ने आउट-ऑफ-डेट वैल्यू के साथ जवाब दिया है, तो कैसेंड्रा क्लाइंट के लिए सबसे हाल के मूल्य को वापस कर देगा। सबसे हाल के मूल्य को वापस करने के बाद, कैसेंड्रा एक प्रदर्शन करता हैread repair पृष्ठभूमि में बासी मूल्यों को अद्यतन करने के लिए।

निम्न आकृति एक योजनाबद्ध दृष्टिकोण दिखाती है कि कैसे कैसेंड्रा एक क्लस्टर में नोड्स के बीच डेटा प्रतिकृति का उपयोग करता है ताकि विफलता का एक भी बिंदु सुनिश्चित न हो सके।

Note - कैसेंड्रा उपयोग करता है Gossip Protocol पृष्ठभूमि में नोड्स को एक दूसरे के साथ संवाद करने और क्लस्टर में किसी भी दोषपूर्ण नोड्स का पता लगाने की अनुमति देने के लिए।

कसंड्रा के घटक

कैसेंड्रा के प्रमुख घटक इस प्रकार हैं -

  • Node - यह वह जगह है जहां डेटा संग्रहीत किया जाता है।

  • Data center - यह संबंधित नोड्स का एक संग्रह है।

  • Cluster - क्लस्टर एक घटक है जिसमें एक या अधिक डेटा केंद्र होते हैं।

  • Commit log- प्रतिबद्ध लॉग कैसेंड्रा में एक दुर्घटना-वसूली तंत्र है। हर लिखने का काम कमिट लॉग को लिखा जाता है।

  • Mem-table- एक मेम-टेबल एक मेमोरी-रेजिडेंट डेटा संरचना है। कमिट लॉग के बाद, डेटा मेम-टेबल को लिखा जाएगा। कभी-कभी, एकल-स्तंभ परिवार के लिए, कई मेम-टेबल होंगे।

  • SSTable - यह एक डिस्क फ़ाइल है, जिसमें डेटा तब मेम-टेबल से फ्लश होता है, जब उसकी सामग्री थ्रेशोल्ड वैल्यू तक पहुँच जाती है।

  • Bloom filter- ये कुछ भी नहीं बल्कि त्वरित, नॉनडेर्मिनिस्टिक, एल्गोरिदम के परीक्षण के लिए हैं कि क्या एक तत्व एक सेट का सदस्य है। यह एक खास तरह का कैश होता है। प्रत्येक फ़िल्टर के बाद ब्लूम फ़िल्टर एक्सेस किए जाते हैं।

कैसंड्रा क्वेरी भाषा

उपयोगकर्ता कैसंड्रा क्वेरी भाषा (CQL) का उपयोग करके अपने नोड्स के माध्यम से कैसेंड्रा तक पहुंच सकते हैं। CQL डेटाबेस का इलाज करता है(Keyspace)तालिकाओं के एक कंटेनर के रूप में। प्रोग्रामर उपयोग करते हैंcqlsh: CQL या अलग अनुप्रयोग भाषा ड्राइवरों के साथ काम करने के लिए संकेत।

ग्राहक अपने रीड-राइट ऑपरेशन के लिए किसी भी नोड्स के पास जाते हैं। वह नोड (समन्वयक) क्लाइंट और डेटा धारण करने वाले नोड्स के बीच एक प्रॉक्सी खेलता है।

संचालन लिखें

नोड्स की हर लेखन गतिविधि द्वारा कब्जा कर लिया जाता है commit logsनोड्स में लिखा है। बाद में डेटा को कैप्चर किया जाएगा और इसमें स्टोर किया जाएगाmem-table. जब भी मेम-टेबल फुल होगी, डेटा में लिखा जाएगा SStableडेटा फ़ाइल। सभी लेखन स्वचालित रूप से पूरे क्लस्टर में विभाजित और दोहराए जाते हैं। कैसेंड्रा समय-समय पर SSTables को समेकित करता है, अनावश्यक डेटा को छोड़ देता है।

संचालन पढ़ें

रीड ऑपरेशन के दौरान, कैसंड्रा ने मेम-टेबल से मान प्राप्त किए और उपयुक्त एसएसटीबल को खोजने के लिए ब्लूम फ़िल्टर की जांच की जो आवश्यक डेटा रखती है।