MongoDB - कैप्ड कलेक्शंस
Capped collectionsफिक्स्ड-आकार के परिपत्र संग्रह हैं जो ऑपरेशन बनाने, पढ़ने और हटाने के लिए उच्च प्रदर्शन का समर्थन करने के लिए सम्मिलन आदेश का पालन करते हैं। परिपत्र द्वारा, इसका मतलब है कि जब संग्रह के लिए आवंटित किया गया निश्चित आकार समाप्त हो जाता है, तो यह संग्रह में सबसे पुराने दस्तावेज़ को बिना कोई स्पष्ट आदेश दिए हटाना शुरू कर देगा।
यदि दस्तावेज़ में दस्तावेज़ आकार में वृद्धि हुई है, तो कैप्ड संग्रह दस्तावेज़ों को अद्यतन प्रतिबंधित करता है। चूंकि डिस्क संग्रह के क्रम में कैप संग्रह संग्रह दस्तावेजों को जमा करता है, यह सुनिश्चित करता है कि दस्तावेज़ का आकार डिस्क पर आवंटित आकार में वृद्धि न करे। लॉग जानकारी, कैश डेटा या किसी अन्य उच्च वॉल्यूम डेटा को संग्रहीत करने के लिए कैप्ड संग्रह सबसे अच्छा है।
कैप्ड कलेक्शन बनाना
कैप्ड कलेक्शन बनाने के लिए, हम सामान्य क्रिएक्लेक्शन कमांड का उपयोग करते हैं लेकिन साथ में capped विकल्प के रूप में true और बाइट्स में संग्रह के अधिकतम आकार को निर्दिष्ट करना।
>db.createCollection("cappedLogCollection",{capped:true,size:10000})
संग्रह आकार के अतिरिक्त, हम संग्रह का उपयोग करके दस्तावेजों की संख्या को सीमित भी कर सकते हैं max पैरामीटर -
>db.createCollection("cappedLogCollection",{capped:true,size:10000,max:1000})
यदि आप जांचना चाहते हैं कि कोई संग्रह छाया हुआ है या नहीं, तो निम्नलिखित का उपयोग करें isCapped कमांड -
>db.cappedLogCollection.isCapped()
यदि कोई मौजूदा संग्रह है जिसे आप कैप्ड में बदलने की योजना बना रहे हैं, तो आप इसे निम्न कोड के साथ कर सकते हैं -
>db.runCommand({"convertToCapped":"posts",size:10000})
यह कोड हमारे मौजूदा संग्रह को बदल देगा posts एक छाया हुआ संग्रह करने के लिए।
छायांकन कैपिंग संग्रह
डिफ़ॉल्ट रूप से, कैप्ड संग्रह पर एक खोज क्वेरी सम्मिलन क्रम में परिणाम प्रदर्शित करेगा। लेकिन अगर आप चाहते हैं कि दस्तावेजों को रिवर्स ऑर्डर में प्राप्त किया जाए, तो उपयोग करेंsort कमांड निम्न कोड में दिखाया गया है -
>db.cappedLogCollection.find().sort({$natural:-1})
जानने के लायक कैप संग्रह के बारे में कुछ अन्य महत्वपूर्ण बिंदु हैं -
हम एक कैप्ड संग्रह से दस्तावेज़ नहीं हटा सकते हैं।
कैप्ड संग्रह में कोई डिफ़ॉल्ट इंडेक्स मौजूद नहीं है, यहां तक कि _id फ़ील्ड पर भी नहीं।
एक नया दस्तावेज़ सम्मिलित करते समय, MongoDB को डिस्क पर नए दस्तावेज़ को समायोजित करने के लिए वास्तव में एक जगह की तलाश नहीं है। यह नेत्रहीन संग्रह की पूंछ पर नए दस्तावेज़ को सम्मिलित कर सकता है। यह बहुत तेजी से छायांकित संग्रह में सम्मिलित संचालन करता है।
इसी तरह, दस्तावेज़ पढ़ते समय MongoDB डिस्क पर मौजूद दस्तावेज़ों को उसी क्रम में देता है। इससे रीड ऑपरेशन बहुत तेज हो जाता है।