Microservice वास्तुकला - परिचय

Microservice एक सेवा-आधारित अनुप्रयोग विकास पद्धति है। इस पद्धति में, बड़े अनुप्रयोगों को सबसे छोटी स्वतंत्र सेवा इकाइयों में विभाजित किया जाएगा। संपूर्ण सेवा को इंटरकनेक्टेड सेवाओं के एक संग्रह के रूप में विभाजित करके, जहां प्रत्येक सेवा केवल एक व्यवसाय की आवश्यकता पर काम करेगी, माइक्रोसिस्टवर्क सेवा-उन्मुख वास्तुकला (SOA) को लागू करने की प्रक्रिया है।

गोइंग माइक्रो का कॉन्सेप्ट

एक सेवा-उन्मुख वास्तुकला में, पूरे सॉफ्टवेयर पैकेज को छोटे, परस्पर व्यापार इकाइयों में उप-विभाजित किया जाएगा। इन छोटी व्यवसाय इकाइयों में से प्रत्येक ग्राहक को सफल व्यवसाय देने के लिए विभिन्न प्रोटोकॉल का उपयोग करते हुए एक-दूसरे से संवाद करेंगे। अब सवाल यह है कि, माइक्रोसैस आर्किटेक्चर (MSA) SOA से कैसे भिन्न है? एक शब्द में, SOA एक डिजाइनिंग पैटर्न है और SOA को कार्यान्वित करने के लिए Microservice एक कार्यान्वयन पद्धति है या हम कह सकते हैं कि Microservice SOA का एक प्रकार है।

कुछ नियम निम्नलिखित हैं जिन्हें हमें माइक्रोसॉर्स्क-उन्मुख एप्लिकेशन विकसित करते समय ध्यान में रखना होगा।

  • Independent - प्रत्येक microservice स्वतंत्र रूप से तैनात किया जाना चाहिए।

  • Coupling - सभी microservices एक दूसरे के साथ शिथिल युग्मित होना चाहिए जैसे कि एक में परिवर्तन दूसरे को प्रभावित नहीं करेगा।

  • Business Goal - पूरे आवेदन की प्रत्येक सेवा इकाई सबसे छोटी होनी चाहिए और एक विशिष्ट व्यावसायिक लक्ष्य देने में सक्षम होनी चाहिए।

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

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

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

उपरोक्त छवि में, आप अलग-अलग उपयोगकर्ताओं और व्यापार डेटा संग्रहीत करने के लिए डेटाबेस जैसे विभिन्न मॉड्यूल देख सकते हैं। फ्रंट-एंड पर, हमारे पास अलग-अलग डिवाइस हैं जहां हम आमतौर पर उपयोगकर्ता या व्यावसायिक डेटा का उपयोग करने के लिए प्रस्तुत करते हैं। बीच में, हमारे पास एक ऐसा पैकेज होता है, जो एक यूएआर या डब्ल्यूएआर फाइल हो सकता है, जो अनुरोधों को स्वीकार करता है ताकि उपयोगकर्ता समाप्त हो जाएं, इसे संसाधनों की मदद से संसाधित करता है, और इसे वापस उपयोगकर्ताओं को प्रदान करता है। जब तक व्यवसाय उपरोक्त उदाहरण में कोई बदलाव नहीं चाहता, तब तक सब कुछ ठीक रहेगा।

निम्नलिखित परिदृश्यों पर विचार करें जहां आपको व्यावसायिक आवश्यकताओं के अनुसार अपना आवेदन बदलना होगा।

व्यावसायिक इकाई को "खोज" मॉड्यूल में कुछ बदलावों की आवश्यकता है। फिर, आपको पूरी खोज प्रक्रिया को बदलने और अपने आवेदन को फिर से तैयार करने की आवश्यकता है। उस स्थिति में, आप बिना किसी बदलाव के अपनी अन्य इकाइयों को फिर से तैयार कर रहे हैं।

अब फिर से आपकी व्यावसायिक इकाई को "वॉलेट" विकल्प को शामिल करने के लिए "चेक आउट" मॉड्यूल में कुछ बदलावों की आवश्यकता है। अब आपको अपना "चेक आउट" मॉड्यूल बदलना होगा और सर्वर में उसी को फिर से डालना होगा। ध्यान दें, आप अपने सॉफ़्टवेयर पैकेजों के विभिन्न मॉड्यूलों को फिर से तैयार कर रहे हैं, जबकि हमने इसमें कोई बदलाव नहीं किया है। यहाँ सेवा-उन्मुख वास्तुकला की अवधारणा और अधिक विशिष्ट है जो माइक्रोसॉर्स्क वास्तुकला के लिए विशिष्ट है। हम अपने अखंड एप्लिकेशन को इस तरह से विकसित कर सकते हैं कि सॉफ्टवेयर के प्रत्येक मॉड्यूल एक स्वतंत्र इकाई के रूप में व्यवहार करेंगे, जो स्वतंत्र रूप से एक एकल व्यवसाय कार्य को संभालने में सक्षम है।

निम्नलिखित उदाहरण पर विचार करें।

उपरोक्त वास्तुकला में, हम कॉम्पैक्ट एंड-टू-एंड सेवा के साथ कोई भी कान फ़ाइल नहीं बना रहे हैं। इसके बजाय, हम उन्हें सेवा के रूप में उजागर करके सॉफ्टवेयर के विभिन्न भागों को विभाजित कर रहे हैं। सॉफ्टवेयर का कोई भी हिस्सा संबंधित सेवाओं का उपभोग करके आसानी से एक-दूसरे के साथ संवाद कर सकता है। यह है कि कैसे आधुनिक वेब अनुप्रयोग में माइक्रोसॉर्स्ट एक महान भूमिका निभाता है।

आइए हम अपने शॉपिंग कार्ट के उदाहरण की तुलना माइक्रोसैस सर्विस में करें। हम अपनी खरीदारी की गाड़ी को "सर्च", "फ़िल्टर", "चेकआउट", "कार्ट", "सिफारिश" आदि जैसे विभिन्न मॉड्यूल में तोड़ सकते हैं। यदि हम शॉपिंग कार्ट पोर्टल बनाना चाहते हैं तो हमें नीचे निर्माण करना होगा उपर्युक्त मॉड्यूल इस तरह से हैं कि वे आपको 24x7 अच्छा खरीदारी अनुभव देने के लिए एक-दूसरे से जुड़ सकते हैं।

फायदे नुकसान

एक मोनोलिथिक एप्लिकेशन का उपयोग करने के बजाय माइक्रोसॉर्स्क का उपयोग करने के फायदे पर कुछ बिंदु निम्नलिखित हैं।

लाभ

  • Small in size- माइक्रोसिस्टम्स SOA डिजाइन पैटर्न का कार्यान्वयन है। आपकी सेवा को जितना संभव हो सके रखने की सिफारिश की जाती है। मूल रूप से, एक सेवा को एक से अधिक व्यावसायिक कार्य नहीं करना चाहिए, इसलिए यह स्पष्ट रूप से आकार में छोटा होगा और किसी भी अन्य अखंड आवेदन की तुलना में आसान होगा।

  • Focused- जैसा कि पहले उल्लेख किया गया है, प्रत्येक माइक्रोसेवा केवल एक व्यवसाय कार्य देने के लिए डिज़ाइन किया गया है। एक माइक्रो सर्विस डिजाइन करते समय, आर्किटेक्ट को सेवा के केंद्र बिंदु के बारे में चिंतित होना चाहिए, जो कि इसकी सुपुर्दगी है। परिभाषा के अनुसार, एक माइक्रोसर्विस प्रकृति में पूर्ण स्टैक होना चाहिए और केवल एक व्यावसायिक संपत्ति देने के लिए प्रतिबद्ध होना चाहिए।

  • Autonomous- प्रत्येक माइक्रोसर्विस पूरे अनुप्रयोग का एक स्वायत्त व्यापार इकाई होना चाहिए। इसलिए, आवेदन अधिक शिथिल हो जाता है, जो रखरखाव लागत को कम करने में मदद करता है।

  • Technology heterogeneity- माइक्रोसॉर्फ़ एक व्यावसायिक इकाई में एक-दूसरे के साथ संचार करने के लिए विभिन्न तकनीकों का समर्थन करता है, जो डेवलपर्स को सही जगह पर सही तकनीक का उपयोग करने में मदद करता है। विषम प्रणाली को लागू करने से, अधिकतम सुरक्षा, गति और एक स्केलेबल प्रणाली प्राप्त की जा सकती है।

  • Resilience- लचीलापन एक सॉफ्टवेयर इकाई को अलग करने की एक संपत्ति है। भवन निर्माण की कार्यप्रणाली में उच्च स्तर की लचीलापन के बाद माइक्रोसिस्टवर्क होता है, इसलिए जब भी एक इकाई विफल होती है तो यह पूरे व्यवसाय को प्रभावित नहीं करता है। लचीलापन एक और संपत्ति है जो अत्यधिक स्केलेबल और कम युग्मित प्रणाली को लागू करता है।

  • Ease of deployment- चूंकि पूरे आवेदन को इकाइयों के छोटे टुकड़े में उप-विभाजित किया गया है, इसलिए प्रत्येक घटक प्रकृति में पूर्ण स्टैक होना चाहिए। उन सभी को किसी भी वातावरण में एक ही तरह के अन्य अखंड अनुप्रयोगों के विपरीत बहुत कम समय जटिलता के साथ आसानी से तैनात किया जा सकता है।

माइक्रोसर्विस आर्किटेक्चर के नुकसान पर कुछ बिंदु निम्नलिखित हैं।

नुकसान

  • Distributed system- तकनीकी विषमता के कारण, विभिन्न तकनीकों का उपयोग एक microservice के विभिन्न भागों को विकसित करने के लिए किया जाएगा। इस बड़े विषम वितरित सॉफ्टवेयर का समर्थन करने के लिए कुशल पेशेवरों के एक विशाल सेट की आवश्यकता होती है। इसलिए, वितरित और विषमता microservice का उपयोग करने के एक नंबर एक नुकसान के रूप में खड़ा है।

  • Cost - माइक्रोसर्विस महंगा है, क्योंकि आपको विभिन्न व्यावसायिक कार्यों के लिए अलग-अलग सर्वर स्थान बनाए रखना है।

  • Enterprise readiness- माइक्रोसॉफ़्ट आर्किटेक्चर को विभिन्न तकनीकों के समूह के रूप में माना जा सकता है, क्योंकि तकनीक दिन-प्रतिदिन विकसित हो रही है। इसलिए, पारंपरिक सॉफ्टवेयर डेवलपमेंट मॉडल की तुलना में एक माइक्रोसेवा एप्लीकेशन एंटरप्राइज तैयार करना काफी मुश्किल है।

SOA से अधिक माइक्रोसेवर

निम्न तालिका SOA और माइक्रोसैस सर्विस की कुछ खासियतों को सूचीबद्ध करती है, जिससे SOA पर माइक्रोसर्विस का उपयोग करने का महत्व सामने आता है।

अंग एसओए Microservice
डिज़ाइन पैटर्न SOA कंप्यूटर सॉफ्टवेयर के लिए एक डिज़ाइन प्रतिमान है, जहाँ सॉफ्टवेयर घटकों को सेवाओं के रूप में उपयोग करने के लिए बाहरी दुनिया से अवगत कराया जाता है। माइक्रो सर्विस SOA का एक हिस्सा है। यह SOA का एक विशेष कार्यान्वयन है।
निर्भरता व्यावसायिक इकाइयाँ एक-दूसरे पर निर्भर हैं। सभी व्यावसायिक इकाइयाँ एक दूसरे से स्वतंत्र हैं।
आकार सॉफ्टवेयर का आकार पारंपरिक सॉफ्टवेयर से बड़ा है। सॉफ्टवेयर का आकार छोटा है।
प्रौद्योगिकी टेक्नॉलॉजी स्टैक माइक्रोसैस सर्विस से कम है। माइक्रोसॉर्स्ट प्रकृति में विषम है क्योंकि सटीक तकनीकों का उपयोग किसी विशिष्ट कार्य को करने के लिए किया जाता है। माइक्रोसर्विसेज को कई तकनीकों का समूह माना जा सकता है।
स्वायत्त और फोकस SOA एप्लिकेशन कई व्यावसायिक कार्यों को करने के लिए बनाए जाते हैं। एकल व्यावसायिक कार्य करने के लिए माइक्रोसॉर्स्ट एप्लिकेशन का निर्माण किया जाता है।
प्रकृति प्रकृति में अखंड। प्रकृति में पूर्ण ढेर।
तैनाती तैनाती समय लेने वाली है। परिनियोजन बहुत आसान है। इसलिए, यह कम समय लेने वाला होगा।
लागत प्रभावशीलता अधिक किफ़ायती। कम लागत वाली।
अनुमापकता Microservices की तुलना में कम। पूरी तरह से तराशा हुआ।
उदाहरण आइए हम एक ऑनलाइन सीएबी बुकिंग आवेदन पर विचार करें। यदि हम SOA का उपयोग करके उस एप्लिकेशन का निर्माण करना चाहते हैं, तो उसकी सॉफ्टवेयर इकाइयाँ होंगी -
  • GetPayments और DriverInformation और MappingDataAPI
  • ऑथेंटिकेटयूजरएंड ड्राइवर्सएपीआई
यदि एक ही एप्लिकेशन को माइक्रोसिस्टवर्क आर्किटेक्चर का उपयोग करके बनाया गया है, तो इसके एपीआई होंगे -
  • SubmitPaymentsService
  • GetDriverInfoService
  • GetMappingDataService
  • AuthenticateUserService
  • AuthenticateDriverService