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

स्व-होस्टेड MongoDB

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

यह सब शुरू में अच्छा लगता है जब तक कि आपका छोटा विचार व्यवसाय में बदलना शुरू नहीं हो जाता और लागत आसमान छूने लगती है। अगर ऐसा नहीं भी है, तब भी यह पोस्ट आपको इसमें शामिल तकनीकी जटिलताओं का एक सामान्य अवलोकन प्रदान करेगी (और रुपये बचाए गए!)

BTW, हम कितनी बचत की बात कर रहे हैं? आइए एक एटलस . के बीच एक त्वरित तुलना करें उदाहरण और AWS . पर एक स्व-होस्टेड MongoDB ।

एटलस (~$166/माह)

$0.23/घंटा उपरोक्त चयनित आवश्यकताओं के आधार पर (~ cloud.mongodb.com)



एडब्ल्यूएस (~$36/माह)

उदाहरण के लिए $0.0416/घंटा और ईबीएस प्रकार और भंडारण के आधार पर अतिरिक्त मूल्य निर्धारण (~ कैलकुलेटर.एडब्ल्यूएस)

<ब्लॉकक्वॉट>

बुनियादी ढांचे के मामले में यह लगभग 4.5 गुना बचत है!

अब जबकि आप प्रमुख कारणों को जानते हैं और अभी भी इस पोस्ट को पढ़ रहे हैं, बिना किसी और हलचल के, आइए तकनीक में गोता लगाएँ।

रूपरेखा

  1. बुनियादी ढांचे की स्थापना
  2. मोंगोडीबी की स्थापना
  3. बल्क माइग्रेशन
  4. कनेक्शन स्विच विलंबता को पाटने के लिए डेल्टा-सिंक (पुराने समूहों पर लागू नहीं)

चूंकि पूरी सामग्री एक ही स्थान पर थोड़ी थकाऊ हो सकती है, इसलिए मैं इसे 2 संबंधित पोस्ट में विभाजित करने जा रहा हूं।

1. आधारभूत संरचना की स्थापना

मैं RedHat Enterprise Linux 8 चलाने वाले इंस्टेंस को सेट करने के लिए गाइड के नीचे उल्लेख करने जा रहा हूं एडब्ल्यूएस पर। ऐसा इसलिए है क्योंकि MongoDB आमतौर पर xfs फ़ाइल-सिस्टम के साथ बेहतर प्रदर्शन करता है। इसे बेहतर ढंग से समझने के लिए यहां एक लेख है।

एक EC2 इंस्टेंस स्पिन करें

मैंने एक t3.small . का उपयोग किया है उदाहरण जो 2 vCPUs . के साथ आता है और 2GB RAM यद्यपि आप अपनी पसंद का कोई भी उदाहरण चुन सकते हैं।

<ब्लॉकक्वॉट>

यह अनुशंसा की जाती है कि आपके DB के पास कम से कम 1GB RAM तक पहुंच होनी चाहिए और 2 वास्तविक कोर क्योंकि यह डिफ़ॉल्ट इंजन WiredTiger द्वारा प्रबंधित कैशिंग और समवर्ती तंत्र के दौरान प्रदर्शन को सीधे प्रभावित करता है . आप रैम और सीपीयू आवश्यकताओं से संबंधित उत्पादन नोटों के बारे में अधिक यहां पढ़ सकते हैं

कॉन्फ़िगरेशन अवलोकन:

  • OS:Redhat Enterprise Linux 8 (x64 इंटेल-आधारित)
  • इंस्टेंस प्रकार:t3.small
  • संग्रहण:10GB (ओएस) + 30GB (डेटा) + 3GB (लॉग) ईबीएस . के यानी 3 अलग-अलग खंड

मुझे लगता है कि आप AWS पर VM बनाने से परिचित हैं।

अब, एक बार इंस्टेंस चालू स्थिति में होने के बाद, एक इलास्टिक आईपी असाइन करें इसके लिए और फिर बस मशीन में रिमोट लॉगिन करें।

<ब्लॉकक्वॉट>

हमें इलास्टिक आईपी की आवश्यकता होगी उदाहरण के लिए सार्वजनिक होस्टनाम सेटअप करने के लिए

$ ssh -i <PEM_FILE> ec2-user@<ELASTIC_IP>

अतिरिक्त वॉल्यूम माउंट करें

हमने डेटा और लॉग के लिए रूट FS के अलावा 2 अतिरिक्त EBS वॉल्यूम जोड़े हैं जिन्हें अभी माउंट किया जाना है (30Gb और 3Gb याद रखें? ) आप वॉल्यूम ब्लॉक का उपयोग करके सूचीबद्ध कर सकते हैं,

$ sudo lsblk

अतिरिक्त वॉल्यूम रूट ब्लॉक के ठीक बाद सूचीबद्ध होंगे (तीर देखें)

ऊपर की छवि में, आप देख सकते हैं कि अतिरिक्त संस्करणों को नाम दिया गया है

  1. xvdb (डेटा स्टोर करने के लिए 30 जीबी स्पेस)
  2. xvdc (लॉग स्टोर करने के लिए 3 जीबी स्पेस)

अब, उन संस्करणों में फाइल-सिस्टम बनाते हैं।

$ sudo mkfs.xfs -L mongodata /dev/xvdb
$ sudo mkfs.xfs -L mongologs /dev/xvdc
<ब्लॉकक्वॉट>

-L वॉल्यूम लेबल सेट करने के लिए एक उपनाम विकल्प है

और फिर वॉल्यूम माउंट करें।

$ sudo mount -t xfs /dev/xvdb /var/lib/mongo
$ sudo mount -t xfs /dev/xvdc /var/log/mongodb

इन परिवर्तनों को प्रतिबिंबित करने के लिए, सिस्टम को रिबूट करना होगा। इसलिए, अब हमें विभाजन की दृढ़ता की भी आवश्यकता है ताकि अनजाने में रिबूट होने की स्थिति में हम डेटाबेस संग्रहण को न खोएं।

हम इसे fstab फ़ाइल में माउंट नियम निर्दिष्ट करके प्राप्त कर सकते हैं। आप इसके बारे में यहाँ और अधिक पढ़ सकते हैं।

इससे पहले आइए उपरोक्त विभाजनों के UUID को कॉपी करें(क्योंकि वे अद्वितीय हैं और सिस्टम पुनरारंभ होने पर नहीं बदलेंगे )

$ sudo blkid

/dev/xvdb . के लिए सूचीबद्ध UUIDs को कॉपी करें और /dev/xvdc . “LABEL” . का संदर्भ लें ब्लॉक पहचान के लिए

अब /etc/fstab खोलें फ़ाइल और कॉन्फ़िगरेशन को निम्न प्रारूप में पेस्ट करें।

UUID=<COPIED_UUID_FOR_DATA> /var/lib/mongo xfs defaults,nofail 0 0
UUID=<COPIED_UUID_FOR_LOGS> /var/log/mongodb xfs defaults,nofail 0 0

होस्टनाम अपडेट करें

होस्टनाम का उपयोग नेटवर्क पर आपके डेटाबेस सर्वर की पहचान करने के लिए किया जाएगा। आप या तो ऊपर दिए गए इलास्टिक आईपी का उपयोग कर सकते हैं या डोमेन नाम (यदि उपलब्ध हो)। /etc/hostname खोलें फ़ाइल और प्रविष्टि संलग्न करें। उदाहरण के लिए

ip-xx.us-east-2.compute.internal **<ELASTIC_IP> <DOMAIN_1> <DOMAIN_2>** ...

प्रक्रिया सीमाएं अपडेट करें (वैकल्पिक)

सिस्टम को स्थिर रखते हुए स्वीकार्य कनेक्शन की अधिकतम संख्या को नियंत्रित करने के लिए यह वैकल्पिक रूप से आवश्यक है। /etc/security/limits.conf खोलें। फ़ाइल करें और निम्न प्रविष्टियाँ जोड़ें।

* soft nofile 64000
* hard nofile 64000
* soft nproc 32000
* hard nproc 32000

अब जबकि इन्फ्रा से संबंधित सभी पूर्वापेक्षाएँ क्रमबद्ध हैं, रिबूट उदाहरण, और चलिए MongoDB स्थापना के लिए आगे बढ़ते हैं।

1. MongoDB सेट करना

रेपो स्रोत जोड़ें

एक फ़ाइल बनाएँ /etc/yum.repos.d/mongodb-org.4.2.repo और निम्नलिखित पैकेज रिपॉजिटरी विवरण जोड़ें।

[mongodb-org-4.2]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/4.2/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-4.2.asc

अब MongoDB इंस्टॉल करें।

$ sudo yum -y install mongodb-org

निर्देशिका और सेटअप अनुमतियां बनाएं

MongoDB डिफ़ॉल्ट रूप से डेटा और आंतरिक लॉग को संग्रहीत करने के लिए निम्न पथों का उपयोग करता है:

<ब्लॉकक्वॉट>

/var/lib/mongo → डेटा
/var/log/mongodb → लॉग्स

निर्देशिका बनाएं

$ sudo mkdir /var/lib/mongo
$ sudo mkdir /var/log/mongodb

उपयोगकर्ता और समूह अनुमतियां बदलें

$ sudo chown mongod:mongod /var/lib/mongo
$ sudo chown mongod:mongod /var/log/mongod

एक व्यवस्थापक उपयोगकर्ता बनाएं

मोंगॉड डेमॉन/सेवा उपयोगकर्ता बनाने के लिए आगे बढ़ने से पहले पहले चलना चाहिए। आइए डिफ़ॉल्ट कॉन्फ़िगरेशन का उपयोग करें (/etc/mongod.conf में संग्रहीत) ) अभी के लिए और डेमॉन प्रक्रिया शुरू करें।

$ sudo -u mongod mongod -f /etc/mongod.conf

उपरोक्त आदेश फोर्क मोड (डिफ़ॉल्ट) में मोंगोड डेमॉन शुरू करेगा।

अब, सर्वर में लॉग इन करें और अपना पहला व्यवस्थापक उपयोगकर्ता बनाएं।

मोंगो खोल खोलें

$ mongo

रूट-व्यवस्थापक बनाने के लिए "व्यवस्थापक" डेटाबेस का उपयोग करें

> use admin

व्यवस्थापक उपयोगकर्ता बनाएं

> db.createUser({user: "admin", pwd: "password", roles: [{role: "root", db: "admin"}]})

एक नियमित उपयोगकर्ता बनाएं

> db.createUser({user: "normal_user", pwd: "password", roles: [{role: "readWriteAnyDatabase", db: "admin"}]})

सर्वर को अभी के लिए शट डाउन करें। हम संशोधित कॉन्‍फ़िगरेशन के साथ पुन:प्रारंभ करेंगे

> db.shutDownServer()

प्रमाणीकरण सेट करना

यहां, हम डेटाबेस प्रमाणीकरण को सक्षम करेंगे और हमारे सर्वर के सार्वजनिक डोमेन में पहुंच योग्य होने के लिए बाइंड-एड्रेस को संशोधित करेंगे। /etc/mongod.conf खोलें। और नीचे दिए गए परिवर्तन करें।

# network interfaces
net:
  port: 27017
  bindIp: 0.0.0.0 # accessible on the network address
security:
  authorization: enabled # creds will be required for making db operations

कॉन्फ़िगरेशन सहेजें और पुनरारंभ करें सर्वर।

$ sudo -u mongod mongod -f /etc/mongod.conf

परीक्षण लॉगिन

आप सत्यापित कर सकते हैं कि क्रेडेंशियल का उपयोग करके काम करते हैं,

$ mongo -u admin -p password

यह प्रारंभिक सेटअप के बारे में है! कृपया मेरी अगली संबंधित पोस्ट के लिए विस्तृत माइग्रेशन प्रक्रिया और डीबी उत्पादन-तैयार रखने के सुझावों के लिए बने रहें।

पी.एस. इस पोस्ट को क्यूरेट करने में मदद करने के लिए पीयूष कुमार को धन्यवाद!


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB वर्तमान उपयोगकर्ता दिखाएं

  2. Mongoengine:ConnectionError:आपने एक डिफ़ॉल्ट कनेक्शन परिभाषित नहीं किया है

  3. प्रमाणीकरण के साथ MongoDB उदाहरणों के लिए कस्टम उपयोगकर्ता कनेक्शन स्ट्रिंग्स

  4. एक मोंगोडब दस्तावेज़ के औसत मूल्य की गणना करें

  5. MongoDB SSPL लाइसेंस परिवर्तन अद्यतन