ओरिएंटबीडी - प्रदर्शन ट्यूनिंग
इस अध्याय में, आप ओरिएंटडीबी का उपयोग करने वाले अपने एप्लिकेशन को अनुकूलित करने के तरीके के बारे में कुछ सामान्य सुझाव प्राप्त कर सकते हैं। विभिन्न प्रकार के डेटाबेस के लिए प्रदर्शन बढ़ाने के तीन तरीके हैं।
Document Database Performance Tuning - यह एक ऐसी तकनीक का उपयोग करता है जो हर नए दस्तावेज़ के लिए दस्तावेज़ निर्माण से बचने में मदद करता है।
Object Database Performance Tuning - यह प्रदर्शन को बेहतर बनाने के लिए जेनेरिक तकनीकों का उपयोग करता है।
Distributed Configuration Tuning - यह वितरित कॉन्फ़िगरेशन में प्रदर्शन को बेहतर बनाने के लिए विभिन्न तरीकों का उपयोग करता है।
आप मेमोरी, जेवीएम और रिमोट कनेक्शन सेटिंग्स को बदलकर सामान्य प्रदर्शन ट्यूनिंग प्राप्त कर सकते हैं।
मेमोरी सेटिंग्स
प्रदर्शन सुधारने के लिए मेमोरी सेटिंग में अलग-अलग रणनीतियाँ हैं।
सर्वर और एंबेडेड सेटिंग्स
ये सेटिंग्स सर्वर घटक और JVM दोनों के लिए मान्य हैं जहाँ जावा एप्लिकेशन को एंबेडेड मोड में OrientDB का उपयोग करके सीधे चलाया जाता है plocal।
ट्यूनिंग पर सबसे महत्वपूर्ण बात यह सुनिश्चित करना है कि मेमोरी सेटिंग्स सही हैं। क्या वास्तविक अंतर बना सकता है मेमोरी मैपिंग द्वारा उपयोग किए जाने वाले ढेर और आभासी मेमोरी के बीच सही संतुलन, विशेष रूप से बड़े डेटासेट (जीबी, टीबी और अधिक) पर जहां निष्क्रिय कैश संरचना कच्चे आईओ से कम गिना जाता है।
उदाहरण के लिए, यदि आप Java प्रक्रिया में अधिकतम 8GB असाइन कर सकते हैं, तो आमतौर पर छोटे हीप और बड़े डिस्क कैश बफर (ऑफ-हीप मेमोरी) को असाइन करना बेहतर होता है।
हीप मेमोरी बढ़ाने के लिए निम्न कमांड का प्रयास करें।
java -Xmx800m -Dstorage.diskCache.bufferSize=7200 ...
storage.diskCache.bufferSize सेटिंग (पुराने "स्थानीय" भंडारण के साथ यह था file.mmap.maxMemory) एमबी में है और बताता है कि डिस्क कैश घटक के लिए कितनी मेमोरी का उपयोग करना है। डिफ़ॉल्ट रूप से यह 4GB है।
NOTE - यदि अधिकतम ढेर और डिस्क कैश बफर का योग बहुत अधिक है, तो यह ओएस को बड़ी मंदी के साथ स्वैप करने का कारण बन सकता है।
जेवीएम सेटिंग्स
JVM सेटिंग्स को सर्वर.sh (और server.bat) बैच फ़ाइलों में एन्कोड किया गया है। आप अपने उपयोग और hw / sw सेटिंग्स के अनुसार जेवीएम को ट्यून करने के लिए उन्हें बदल सकते हैं। निम्न लाइन को server.bat फ़ाइल में जोड़ें।
-server -XX:+PerfDisableSharedMem
यह सेटिंग JVM के बारे में डिबग जानकारी लिखने को अक्षम कर देगी। यदि आपको जेवीएम को प्रोफाइल करने की आवश्यकता है, तो इस सेटिंग को हटा दें।
रिमोट कनेक्शन
दूरस्थ कनेक्शन का उपयोग करके डेटाबेस तक पहुँचने पर प्रदर्शन को बेहतर बनाने के कई तरीके हैं।
रणनीति लाना
जब आप एक दूरस्थ डेटाबेस के साथ काम करते हैं तो आपको इस्तेमाल की गई रणनीति पर ध्यान देना होगा। डिफ़ॉल्ट रूप से, OrientDB क्लाइंट केवल परिणाम में निहित रिकॉर्ड लोड करता है। उदाहरण के लिए, यदि कोई क्वेरी 100 तत्वों को लौटाती है, लेकिन यदि आप क्लाइंट से इन तत्वों को पार करते हैं, तो ओरिएंटबीडी क्लाइंट आलसी तत्वों को प्रत्येक मिस्ड रिकॉर्ड के लिए सर्वर पर एक और नेटवर्क कॉल के साथ लोड करता है।
नेटवर्क कनेक्शन पूल
प्रत्येक क्लाइंट, डिफ़ॉल्ट रूप से, सर्वर से बात करने के लिए केवल एक नेटवर्क कनेक्शन का उपयोग करता है। एक ही क्लाइंट पर कई थ्रेड्स समान नेटवर्क कनेक्शन पूल साझा करते हैं।
जब आपके पास कई थ्रेड्स होते हैं, तो एक टोंटी हो सकती है क्योंकि मुफ्त नेटवर्क कनेक्शन की प्रतीक्षा में बहुत समय बीत जाता है। यही कारण है कि नेटवर्क कनेक्शन पूल को कॉन्फ़िगर करना महत्वपूर्ण है।
विन्यास बहुत सरल है, सिर्फ 2 पैरामीटर -
minPool- यह कनेक्शन पूल का प्रारंभिक आकार है। डिफ़ॉल्ट मान को वैश्विक पैरामीटर "client.channel.minPool" के रूप में कॉन्फ़िगर किया गया है।
maxPool- यह अधिकतम आकार है जो कनेक्शन पूल तक पहुंच सकता है। डिफ़ॉल्ट मान को वैश्विक पैरामीटर "client.channel.maxPool" के रूप में कॉन्फ़िगर किया गया है।
यदि सभी पूल कनेक्शन व्यस्त हैं, तो क्लाइंट थ्रेड पहले मुफ्त कनेक्शन की प्रतीक्षा करेगा।
डेटाबेस गुणों का उपयोग करके कॉन्फ़िगरेशन का उदाहरण।
database = new ODatabaseDocumentTx("remote:localhost/demo");
database.setProperty("minPool", 2);
database.setProperty("maxPool", 5);
database.open("admin", "admin");
वितरित कॉन्फ़िगरेशन ट्यूनिंग
वितरित कॉन्फ़िगरेशन पर प्रदर्शन को बेहतर बनाने के कई तरीके हैं।
लेन-देन का उपयोग करें
यहां तक कि जब आप ग्राफ़ अपडेट करते हैं, तो आपको हमेशा लेनदेन में काम करना चाहिए। OrientDB आपको उनके बाहर काम करने की अनुमति देता है। सामान्य मामले केवल पढ़ने के लिए प्रश्न हैं या विफलता के मामले में बड़े पैमाने पर और गैर-समवर्ती संचालन बहाल किए जा सकते हैं। जब आप वितरित कॉन्फ़िगरेशन पर चलते हैं, तो लेन-देन का उपयोग विलंबता को कम करने में मदद करता है। ऐसा इसलिए है क्योंकि वितरित ऑपरेशन केवल प्रतिबद्ध समय पर होता है। विलंबता के कारण, कई बड़े ऑपरेशनों को स्थानांतरित करने की तुलना में एक बड़ा ऑपरेशन वितरित करना बहुत अधिक कुशल है।
प्रतिकृति बनाम साझाकरण
OrientDB वितरित कॉन्फ़िगरेशन पूर्ण प्रतिकृति पर सेट है। डेटाबेस की एक ही कॉपी के साथ कई नोड्स होना स्केल रीड्स के लिए महत्वपूर्ण है। वास्तव में, प्रत्येक सर्वर रीड्स और क्वेरी को निष्पादित करने के लिए स्वतंत्र है। यदि आपके पास 10 सर्वर नोड हैं, तो रीड थ्रूपुट 10x है।
लिखने के साथ, यह विपरीत है: पूर्ण प्रतिकृति के साथ कई नोड्स होने पर संचालन धीमा हो जाता है, अगर प्रतिकृति तुल्यकालिक है। इस स्थिति में, कई नोड्स में डेटाबेस को शार्प करने से आप राइट अप को स्केल कर सकते हैं, क्योंकि केवल नोड्स का एक सबसेट राइट पर शामिल होता है। इसके अलावा, आपके पास एक सर्वर नोड एचडी से बड़ा डेटाबेस हो सकता है।
राइट्स पर स्केल
यदि आपके पास एक धीमा नेटवर्क है और आपके पास एक सिंक्रोनस (डिफ़ॉल्ट) प्रतिकृति है, तो आप विलंबता की लागत का भुगतान कर सकते हैं। वास्तव में जब ओरिएंटडीबी सिंक्रोनाइज़ करता है, तो यह कम से कम इंतजार करता हैwriteQuorum। इसका मतलब यह है कि अगर राइटक्वाउम 3 है, और आपके पास 5 नोड्स हैं, तो समन्वयक सर्वर नोड (जहां वितरित ऑपरेशन शुरू किया गया है) को क्लाइंट को जवाब देने के लिए कम से कम 3 नोड्स से उत्तर की प्रतीक्षा करनी होगी।
स्थिरता बनाए रखने के लिए, राइटअकोरम को बहुमत पर सेट किया जाना चाहिए। यदि आपके पास 5 नोड हैं, तो बहुमत 3 है। 4 नोड्स के साथ, यह अभी भी 3 है। 4 या 5 के बजाय 3 को राइटक्कोरम सेट करना विलंबता लागत को कम करने और अभी भी स्थिरता बनाए रखने की अनुमति देता है।
अतुल्यकालिक प्रतिकृति
चीजों को गति देने के लिए, आप विलंबता की अड़चन को दूर करने के लिए अतुल्यकालिक प्रतिकृति सेट कर सकते हैं। इस मामले में, समन्वयक सर्वर नोड स्थानीय रूप से ऑपरेशन को निष्पादित करता है और क्लाइंट को जवाब देता है। संपूर्ण प्रतिकृति पृष्ठभूमि में होगी। यदि कोरम तक नहीं पहुंचा जाता है, तो परिवर्तनों को पारदर्शी रूप से वापस लाया जाएगा।
रीड्स पर स्केल
यदि आप पहले से ही अधिकांश नोड्स के लिए राइटअकोरम सेट करते हैं, तो आप इसे छोड़ सकते हैं readQuorumसे 1 (डिफ़ॉल्ट)। यह सभी रीड्स को गति देता है।