माइक्रोसवर्क आर्किटेक्चर - स्केलिंग
स्केलिंग विभिन्न इकाइयों में एक सॉफ्टवेयर को तोड़ने की एक प्रक्रिया है। स्केलिंग के मामले में स्केलिंग भी परिभाषित करता है। स्केलेबिलिटी एप्लिकेशन की अधिक अग्रिम विशेषताओं को लागू करने की क्षमता है। यह सुरक्षा, स्थायित्व और अनुप्रयोग की स्थिरता में सुधार करने में मदद करता है। हमारे पास तीन प्रकार की स्केलिंग प्रक्रियाएं हैं जिनका पालन उद्योगों में किया जाता है। निम्नलिखित वास्तविक जीवन के उदाहरणों के साथ अलग-अलग स्केलिंग पद्धति हैं।
एक्स-एक्सिस स्केलिंग
एक्स-एक्सिस स्केलिंग को क्षैतिज स्केलिंग भी कहा जाता है। इस प्रक्रिया में, पूरे एप्लिकेशन को विभिन्न क्षैतिज भागों में उप-विभाजित किया जाता है। आम तौर पर, किसी भी वेब सर्वर एप्लिकेशन में इस प्रकार का स्केलिंग हो सकता है। एक सामान्य MVC आर्किटेक्चर पर विचार करें जो क्षैतिज स्केलिंग का अनुसरण करता है जैसा कि निम्न आकृति में दिखाया गया है।
एक उदाहरण के रूप में, हम किसी भी JSP सर्वलेट एप्लिकेशन पर विचार कर सकते हैं। इस एप्लिकेशन में, नियंत्रक हर अनुरोध को नियंत्रित करता है और यह जब भी आवश्यक हो, मॉडल के साथ संवाद करके दृश्य उत्पन्न करेगा। आम तौर पर, अखंड अनुप्रयोग इस स्केलिंग विधि का पालन करते हैं। एक्स-एक्सिस स्केलिंग प्रकृति में बहुत ही बुनियादी है और इसमें बहुत कम समय लगता है। इस पद्धति में, एक सॉफ्टवेयर को उसके अलग-अलग कार्य के आधार पर स्केल किया जाएगा जो इकाई के लिए जिम्मेदार है। उदाहरण के लिए, नियंत्रक आवक और आउटगोइंग अनुरोध को नियंत्रित करने के लिए ज़िम्मेदार है, दृश्य ब्राउज़र में उपयोगकर्ताओं को व्यावसायिक कार्यक्षमता का प्रतिनिधित्व करने के लिए जिम्मेदार है, जबकि मॉडल हमारे डेटा को संग्रहीत करने के लिए ज़िम्मेदार है और यह डेटाबेस के रूप में काम करता है।
वाई-एक्सिस स्केलिंग
Y- अक्ष स्केलिंग को वर्टिकल स्केलिंग भी कहा जाता है जिसमें किसी भी संसाधन स्तर स्केलिंग शामिल है। किसी भी DBaaS या Hadoop सिस्टम को Y- अक्ष स्केल माना जा सकता है। इस प्रकार के स्केलिंग में, उपयोगकर्ताओं के अनुरोध को कुछ तर्क को लागू करके पुनर्निर्देशित और प्रतिबंधित किया जाता है।
आइए हम फेसबुक को एक उदाहरण के रूप में मानते हैं। फेसबुक को हर सेकंड में 1.79 मिलियन उपयोगकर्ताओं को संभालने की आवश्यकता है; इसलिए, यातायात को नियंत्रित करना फेसबुक नेटवर्क इंजीनियरों की एक बड़ी जिम्मेदारी है। किसी भी खतरे से उबरने के लिए, वे वाई-अक्ष स्केलिंग का पालन करते हैं जिसमें एक ही समय में एक ही एप्लिकेशन के साथ कई सर्वर चलाना शामिल है। अब ट्रैफ़िक के इस विशाल स्तर को नियंत्रित करने के लिए, फेसबुक एक क्षेत्र से एक विशिष्ट सर्वर तक सभी ट्रैफ़िक को पुनर्निर्देशित करता है, जैसा कि चित्र में दिखाया गया है। क्षेत्र पर आधारित यातायात के इस हस्तांतरण को वास्तु भाषा में लोड संतुलन कहा जाता है।
छोटी स्वतंत्र व्यावसायिक इकाइयों में संसाधनों को तोड़ने की इस पद्धति को वाई-एक्सिस स्केलिंग के रूप में जाना जाता है।
जेड-एक्सिस स्केलिंग
X- और Y- अक्ष स्केलिंग को समझना बहुत आसान है। हालांकि, व्यावसायिक स्तर पर एक एप्लिकेशन को भी स्केल किया जा सकता है, जिसे जेड-एक्सिस स्केलिंग कहा जाता है। निम्नलिखित व्यावसायिक इकाइयों के विभिन्न वर्टिकल में कैब सर्विस एप्लिकेशन को स्केल करने का एक उदाहरण है।
स्केलिंग के फायदे
Cost - एक सॉफ्टवेयर के उचित स्केलिंग से रखरखाव की लागत कम हो जाएगी।
Performance - ढीले युग्मन के कारण, एक ठीक से स्केल किए गए सॉफ़्टवेयर का प्रदर्शन हमेशा गैर-स्केल किए गए सॉफ़्टवेयर से बेहतर होता है।
Load distribution - विभिन्न तकनीकों का उपयोग करके, हम आसानी से अपने सर्वर लोड को बनाए रख सकते हैं।
Reuse - एक सॉफ्टवेयर की स्केलेबिलिटी सॉफ्टवेयर की उपयोगिता को भी बढ़ाती है।