Microservice वास्तुकला - त्वरित गाइड
Microservice एक सेवा-आधारित अनुप्रयोग विकास पद्धति है। इस पद्धति में, बड़े अनुप्रयोगों को सबसे छोटी स्वतंत्र सेवा इकाइयों में विभाजित किया जाएगा। संपूर्ण सेवा को इंटरकनेक्टेड सेवाओं के संग्रह के रूप में विभाजित करते हुए, सेवा-उन्मुख वास्तुकला (SOA) को लागू करने की प्रक्रिया है, जहां प्रत्येक सेवा केवल एक व्यवसाय की आवश्यकता होगी।
गोइंग माइक्रो का कॉन्सेप्ट
एक सेवा-उन्मुख वास्तुकला में, पूरे सॉफ्टवेयर पैकेज को छोटे, परस्पर व्यापार इकाइयों में उप-विभाजित किया जाएगा। इन छोटी व्यवसाय इकाइयों में से प्रत्येक ग्राहक को सफल व्यवसाय देने के लिए विभिन्न प्रोटोकॉल का उपयोग करते हुए एक-दूसरे से संवाद करेंगे। अब सवाल यह है कि, माइक्रोसैस आर्किटेक्चर (MSA) SOA से कैसे भिन्न है? एक शब्द में, SOA एक डिजाइनिंग पैटर्न है और SOA को कार्यान्वित करने के लिए Microservice एक कार्यान्वयन पद्धति है या हम कह सकते हैं कि Microservice SOA का एक प्रकार है।
कुछ नियम निम्नलिखित हैं जिन्हें हमें माइक्रोसोर्स्क-उन्मुख एप्लिकेशन विकसित करते समय ध्यान में रखना होगा।
Independent - प्रत्येक microservice स्वतंत्र रूप से तैनात किया जाना चाहिए।
Coupling - सभी माइक्रोसर्विसेज को एक दूसरे के साथ शिथिल रूप से जोड़ा जाना चाहिए ताकि एक में परिवर्तन दूसरे को प्रभावित न करें।
Business Goal - पूरे आवेदन की प्रत्येक सेवा इकाई सबसे छोटी होनी चाहिए और एक विशिष्ट व्यावसायिक लक्ष्य देने में सक्षम होनी चाहिए।
आइए हम माइक्रोसर्विस को गहराई से समझने के लिए ऑनलाइन शॉपिंग पोर्टल के एक उदाहरण पर विचार करें। अब, इस पूरे ई-कॉमर्स पोर्टल को उपयोगकर्ता प्रबंधन, ऑर्डर प्रबंधन, चेक-इन, भुगतान प्रबंधन, वितरण प्रबंधन आदि जैसी छोटी व्यावसायिक इकाइयों में तोड़ दें। एक सफल ऑर्डर को इन सभी मॉड्यूल के माध्यम से एक विशिष्ट समय के भीतर आगे बढ़ने की आवश्यकता है। फ्रेम। निम्नलिखित एक इलेक्ट्रॉनिक वाणिज्य प्रणाली से जुड़ी विभिन्न व्यावसायिक इकाइयों की समेकित छवि है।
इन व्यापार मॉड्यूलों में से प्रत्येक का अपना व्यावसायिक तर्क और हितधारक होना चाहिए। वे कुछ विशिष्ट जरूरतों के लिए तीसरे पक्ष के वेंडर से संपर्क करते हैं, और एक दूसरे के साथ भी। उदाहरण के लिए, आदेश प्रबंधन उपयोगकर्ता जानकारी प्राप्त करने के लिए उपयोगकर्ता प्रबंधन के साथ संवाद कर सकता है।
अब, यह देखते हुए कि आप पहले बताई गई इन सभी व्यावसायिक इकाइयों के साथ एक ऑनलाइन शॉपिंग पोर्टल चला रहे हैं, आपको कुछ लेवल लेवल एप्लिकेशन की आवश्यकता होती है, जिसमें विभिन्न लेयर्स जैसे फ्रंट-एंड, बैक-एंड, डेटाबेस इत्यादि शामिल हैं, यदि आपका एप्लिकेशन स्केल नहीं किया गया है। और पूरी तरह से एक एकल युद्ध फ़ाइल में विकसित किया गया है, फिर इसे एक विशिष्ट अखंड अनुप्रयोग के रूप में कहा जाएगा। आईबीएम के अनुसार, एक विशिष्ट अखंड एप्लिकेशन में आंतरिक रूप से निम्नलिखित मॉड्यूल संरचना होनी चाहिए जहां सभी उपयोगकर्ता अनुरोधों को संभालने के लिए केवल एक समापन बिंदु या एप्लिकेशन जिम्मेदार होगा।
उपरोक्त छवि में, आप अलग-अलग उपयोगकर्ताओं और व्यापार डेटा संग्रहीत करने के लिए डेटाबेस जैसे विभिन्न मॉड्यूल देख सकते हैं। फ्रंट-एंड पर, हमारे पास अलग-अलग डिवाइस हैं जहां हम आमतौर पर उपयोगकर्ता या व्यावसायिक डेटा का उपयोग करने के लिए प्रस्तुत करते हैं। बीच में, हमारे पास एक ऐसा पैकेज होता है जो एक यूएआर या डब्ल्यूएआर फाइल हो सकता है जो अनुरोधों को स्वीकार करता है ताकि उपयोगकर्ता समाप्त हो जाएं, इसे संसाधनों की मदद से संसाधित करता है, और इसे वापस उपयोगकर्ताओं को प्रदान करता है। जब तक व्यवसाय उपरोक्त उदाहरण में कोई बदलाव नहीं चाहता तब तक सब कुछ ठीक रहेगा।
निम्नलिखित परिदृश्यों पर विचार करें जहां आपको व्यावसायिक आवश्यकताओं के अनुसार अपना आवेदन बदलना होगा।
व्यावसायिक इकाई को "खोज" मॉड्यूल में कुछ बदलावों की आवश्यकता है। फिर, आपको पूरी खोज प्रक्रिया को बदलने और अपने आवेदन को फिर से तैयार करने की आवश्यकता है। उस स्थिति में, आप बिना किसी बदलाव के अपनी अन्य इकाइयों को फिर से तैयार कर रहे हैं।
अब फिर से आपकी व्यावसायिक इकाई को "वॉलेट" विकल्प को शामिल करने के लिए "चेक आउट" मॉड्यूल में कुछ बदलावों की आवश्यकता है। अब आपको अपना "चेक आउट" मॉड्यूल बदलना होगा और सर्वर में उसी को फिर से डालना होगा। ध्यान दें, आप अपने सॉफ़्टवेयर पैकेजों के विभिन्न मॉड्यूलों को फिर से तैयार कर रहे हैं, जबकि हमने इसमें कोई बदलाव नहीं किया है। यहाँ सेवा-उन्मुख वास्तुकला की अवधारणा और अधिक विशिष्ट है जो माइक्रोसॉर्स्क वास्तुकला के लिए विशिष्ट है। हम अपने अखंड अनुप्रयोग को इस तरह से विकसित कर सकते हैं कि सॉफ्टवेयर का प्रत्येक मॉड्यूल एक स्वतंत्र इकाई के रूप में व्यवहार करेगा, जो स्वतंत्र रूप से एक ही व्यवसाय कार्य को संभालने में सक्षम है।
निम्नलिखित उदाहरण पर विचार करें।
उपरोक्त वास्तुकला में, हम कॉम्पैक्ट एंड-टू-एंड सेवा के साथ कोई भी कान फ़ाइल नहीं बना रहे हैं। इसके बजाय, हम उन्हें सेवा के रूप में उजागर करके सॉफ्टवेयर के विभिन्न भागों को विभाजित कर रहे हैं। सॉफ्टवेयर का कोई भी हिस्सा संबंधित सेवाओं का उपभोग करके आसानी से एक-दूसरे के साथ संवाद कर सकता है। यह है कि कैसे आधुनिक वेब अनुप्रयोग में माइक्रोसॉर्स्ट एक महान भूमिका निभाता है।
आइए हम अपने शॉपिंग कार्ट के उदाहरण की तुलना माइक्रोसैस सर्विस में करें। हम अपनी खरीदारी की गाड़ी को "सर्च", "फ़िल्टर", "चेकआउट", "कार्ट", "सिफारिश" आदि जैसे विभिन्न मॉड्यूल में तोड़ सकते हैं। यदि हम शॉपिंग कार्ट का पोर्टल बनाना चाहते हैं तो हमें निर्माण करना होगा। उपर्युक्त मॉड्यूल इस तरह से हैं कि वे आपको 24x7 अच्छे खरीदारी अनुभव देने के लिए एक-दूसरे से जुड़ सकते हैं।
फायदे नुकसान
एक मोनोलिथिक एप्लिकेशन का उपयोग करने के बजाय माइक्रोसॉर्स्क का उपयोग करने के फायदे पर कुछ बिंदु निम्नलिखित हैं।
लाभ
Small in size- माइक्रोसिस्टम्स SOA डिजाइन पैटर्न का कार्यान्वयन है। आपकी सेवा को जितना संभव हो सके रखने की सिफारिश की जाती है। मूल रूप से, एक सेवा को एक से अधिक व्यावसायिक कार्य नहीं करना चाहिए, इसलिए यह स्पष्ट रूप से आकार में छोटा होगा और किसी भी अन्य अखंड आवेदन की तुलना में आसान होगा।
Focused- जैसा कि पहले उल्लेख किया गया है, प्रत्येक माइक्रोसेवा सेवा केवल एक व्यवसाय कार्य देने के लिए डिज़ाइन की गई है। एक माइक्रो सर्विस डिजाइन करते समय, आर्किटेक्ट को सेवा के केंद्र बिंदु के बारे में चिंतित होना चाहिए, जो कि इसकी सुपुर्दगी है। परिभाषा के अनुसार, एक माइक्रोसेवा को प्रकृति में पूर्ण स्टैक होना चाहिए और केवल एक व्यावसायिक संपत्ति देने के लिए प्रतिबद्ध होना चाहिए।
Autonomous- प्रत्येक microservice पूरे आवेदन की एक स्वायत्त व्यापार इकाई होनी चाहिए। इसलिए, आवेदन अधिक शिथिल हो जाता है, जो रखरखाव लागत को कम करने में मदद करता है।
Technology heterogeneity- माइक्रोसॉर्फ़ एक व्यावसायिक इकाई में एक दूसरे के साथ संचार करने के लिए विभिन्न तकनीकों का समर्थन करता है, जो डेवलपर्स को सही जगह पर सही तकनीक का उपयोग करने में मदद करता है। विषम प्रणाली को लागू करने से, अधिकतम सुरक्षा, गति और एक स्केलेबल प्रणाली प्राप्त की जा सकती है।
Resilience- लचीलापन एक सॉफ्टवेयर इकाई को अलग करने की एक संपत्ति है। भवन निर्माण की कार्यप्रणाली में उच्च स्तर की लचीलापन के बाद माइक्रोसिस्टवर्क होता है, इसलिए जब भी एक इकाई विफल होती है तो यह पूरे व्यवसाय को प्रभावित नहीं करता है। लचीलापन एक और संपत्ति है जो उच्च स्केलेबल और कम युग्मित प्रणाली को लागू करता है।
Ease of deployment- जैसा कि पूरे आवेदन को इकाइयों के छोटे टुकड़े में उप-विभाजित किया गया है, प्रत्येक घटक को प्रकृति में पूर्ण स्टैक होना चाहिए। उन सभी को किसी भी वातावरण में एक ही तरह के अन्य अखंड अनुप्रयोगों के विपरीत बहुत कम समय जटिलता के साथ आसानी से तैनात किया जा सकता है।
माइक्रोसर्विस आर्किटेक्चर के नुकसान पर कुछ बिंदु निम्नलिखित हैं।
नुकसान
Distributed system- तकनीकी विषमता के कारण, विभिन्न तकनीकों का उपयोग एक microservice के विभिन्न भागों को विकसित करने के लिए किया जाएगा। इस बड़े विषम वितरित सॉफ्टवेयर का समर्थन करने के लिए कुशल पेशेवरों के एक विशाल सेट की आवश्यकता होती है। इसलिए, वितरित और विषमता microservice का उपयोग करने के एक नंबर एक नुकसान के रूप में खड़ा है।
Cost - माइक्रोसर्विस महंगा है, क्योंकि आपको विभिन्न व्यावसायिक कार्यों के लिए अलग-अलग सर्वर स्थान बनाए रखना है।
Enterprise readiness- माइक्रोसॉफ़्ट आर्किटेक्चर को विभिन्न तकनीकों के समूह के रूप में माना जा सकता है, क्योंकि तकनीक दिन-प्रतिदिन विकसित हो रही है। इसलिए, पारंपरिक सॉफ्टवेयर विकास मॉडल की तुलना में एक माइक्रोसेवा एप्लीकेशन एंटरप्राइज तैयार करना काफी कठिन है।
SOA से अधिक माइक्रोसेवर
निम्न तालिका SOA और माइक्रोसैस सर्विस की कुछ विशेषताओं को सूचीबद्ध करती है, जिससे SOA पर माइक्रोसैस सर्विस का उपयोग करने का महत्व सामने आता है।
अंग | एसओए | Microservice |
---|---|---|
डिज़ाइन पैटर्न | SOA कंप्यूटर सॉफ्टवेयर के लिए एक डिजाइन प्रतिमान है, जहां सॉफ्टवेयर घटकों को सेवाओं के रूप में उपयोग के लिए बाहरी दुनिया से अवगत कराया जाता है। | माइक्रो सर्विस SOA का एक हिस्सा है। यह SOA का एक विशेष कार्यान्वयन है। |
निर्भरता | व्यावसायिक इकाइयाँ एक-दूसरे पर निर्भर हैं। | सभी व्यावसायिक इकाइयाँ एक दूसरे से स्वतंत्र हैं। |
आकार | सॉफ्टवेयर का आकार पारंपरिक सॉफ्टवेयर से बड़ा है। | सॉफ्टवेयर का आकार छोटा है। |
प्रौद्योगिकी | टेक्नॉलॉजी स्टैक माइक्रोसैस सर्विस से कम है। | माइक्रोसॉर्स्ट प्रकृति में विषम है क्योंकि सटीक तकनीकों का उपयोग किसी विशिष्ट कार्य को करने के लिए किया जाता है। माइक्रोसर्विसेज को कई तकनीकों का समूह माना जा सकता है। |
स्वायत्त और फोकस | SOA एप्लिकेशन कई व्यावसायिक कार्यों को करने के लिए बनाए जाते हैं। | एकल व्यावसायिक कार्य करने के लिए माइक्रोसॉर्स्ट एप्लिकेशन का निर्माण किया जाता है। |
प्रकृति | प्रकृति में अखंड। | प्रकृति में पूर्ण ढेर। |
तैनाती | तैनाती समय लेने वाली है। | परिनियोजन बहुत आसान है। इसलिए, यह कम समय लेने वाला होगा। |
लागत प्रभावशीलता | अधिक किफ़ायती। | कम लागत वाला। |
अनुमापकता | Microservices की तुलना में कम। | पूरी तरह से तराशा हुआ। |
उदाहरण | आइए हम एक ऑनलाइन सीएबी बुकिंग आवेदन पर विचार करें। यदि हम SOA का उपयोग करके उस एप्लिकेशन का निर्माण करना चाहते हैं, तो उसकी सॉफ्टवेयर इकाइयाँ होंगी -
|
यदि एक ही एप्लिकेशन को माइक्रोसिस्टवर्क आर्किटेक्चर का उपयोग करके बनाया गया है, तो इसके एपीआई होंगे -
|
स्केलिंग विभिन्न इकाइयों में एक सॉफ्टवेयर को तोड़ने की एक प्रक्रिया है। स्केलिंग के मामले में स्केलिंग भी परिभाषित करता है। स्केलेबिलिटी एप्लिकेशन की अधिक अग्रिम विशेषताओं को लागू करने की क्षमता है। यह सुरक्षा, स्थायित्व और अनुप्रयोग की स्थिरता को बेहतर बनाने में मदद करता है। हमारे पास तीन प्रकार की स्केलिंग प्रक्रियाएं हैं जिनका पालन उद्योगों में किया जाता है। निम्नलिखित वास्तविक जीवन के उदाहरणों के साथ अलग-अलग स्केलिंग पद्धति हैं।
एक्स-एक्सिस स्केलिंग
एक्स-एक्सिस स्केलिंग को क्षैतिज स्केलिंग भी कहा जाता है। इस प्रक्रिया में, पूरे एप्लिकेशन को विभिन्न क्षैतिज भागों में उप-विभाजित किया जाता है। आम तौर पर, किसी भी वेब सर्वर एप्लिकेशन में इस प्रकार का स्केलिंग हो सकता है। सामान्य MVC आर्किटेक्चर पर विचार करें जो क्षैतिज स्केलिंग का अनुसरण करता है जैसा कि निम्न आकृति में दिखाया गया है।
एक उदाहरण के रूप में, हम किसी भी JSP सर्वलेट एप्लिकेशन पर विचार कर सकते हैं। इस एप्लिकेशन में, नियंत्रक हर अनुरोध को नियंत्रित करता है और यह जब भी आवश्यक हो, मॉडल के साथ संवाद करके दृश्य उत्पन्न करेगा। आम तौर पर, अखंड अनुप्रयोग इस स्केलिंग विधि का पालन करते हैं। एक्स-एक्सिस स्केलिंग प्रकृति में बहुत ही बुनियादी है और इसमें बहुत कम समय लगता है। इस पद्धति में, एक सॉफ्टवेयर को उसके अलग-अलग कार्यों के आधार पर स्केल किया जाएगा जो इकाई के लिए जिम्मेदार है। उदाहरण के लिए, आने वाले और बाहर जाने वाले अनुरोध को नियंत्रित करने के लिए नियंत्रक जिम्मेदार है, ब्राउज़र में उपयोगकर्ताओं को व्यावसायिक कार्यक्षमता का प्रतिनिधित्व करने के लिए जिम्मेदार है, जबकि मॉडल हमारे डेटा को संग्रहीत करने के लिए जिम्मेदार है और यह डेटाबेस के रूप में काम करता है।
वाई-एक्सिस स्केलिंग
Y- अक्ष स्केलिंग को वर्टिकल स्केलिंग भी कहा जाता है जिसमें किसी भी संसाधन स्तर स्केलिंग शामिल है। किसी भी DBaaS या Hadoop सिस्टम को Y- अक्ष स्केल माना जा सकता है। इस प्रकार के स्केलिंग में, उपयोगकर्ताओं के अनुरोध को कुछ तर्क को लागू करके पुनर्निर्देशित और प्रतिबंधित किया जाता है।
आइए हम फेसबुक को एक उदाहरण के रूप में मानते हैं। फेसबुक को हर सेकंड में 1.79 मिलियन उपयोगकर्ताओं को संभालने की आवश्यकता है; इसलिए, यातायात को नियंत्रित करना फेसबुक नेटवर्क इंजीनियरों की बहुत बड़ी जिम्मेदारी है। किसी भी खतरे से उबरने के लिए, वे वाई-अक्ष स्केलिंग का पालन करते हैं जिसमें एक ही समय में एक ही एप्लिकेशन के साथ कई सर्वर चलाना शामिल है। अब ट्रैफ़िक के इस विशाल स्तर को नियंत्रित करने के लिए, फेसबुक एक क्षेत्र से एक विशिष्ट सर्वर तक सभी ट्रैफ़िक को पुनर्निर्देशित करता है, जैसा कि चित्र में दिखाया गया है। क्षेत्र के आधार पर यातायात के इस हस्तांतरण को वास्तु भाषा में लोड संतुलन कहा जाता है।
छोटी स्वतंत्र व्यावसायिक इकाइयों में संसाधनों को तोड़ने की इस पद्धति को वाई-एक्सिस स्केलिंग के रूप में जाना जाता है।
जेड-एक्सिस स्केलिंग
X- और Y- अक्ष स्केलिंग को समझना बहुत आसान है। हालांकि, व्यावसायिक स्तर पर एक एप्लिकेशन को भी स्केल किया जा सकता है, जिसे जेड-एक्सिस स्केलिंग कहा जाता है। निम्नलिखित व्यावसायिक इकाइयों के विभिन्न वर्टिकल में कैब सर्विस एप्लिकेशन को स्केल करने का एक उदाहरण है।
स्केलिंग के फायदे
Cost - एक सॉफ्टवेयर के उचित स्केलिंग से रखरखाव की लागत कम हो जाएगी।
Performance - ढीले युग्मन के कारण, एक ठीक से स्केल किए गए सॉफ़्टवेयर का प्रदर्शन हमेशा गैर-स्केल किए गए सॉफ़्टवेयर से बेहतर होता है।
Load distribution - विभिन्न तकनीकों का उपयोग करके, हम आसानी से अपने सर्वर लोड को बनाए रख सकते हैं।
Reuse - एक सॉफ्टवेयर की स्केलेबिलिटी सॉफ्टवेयर की उपयोगिता को भी बढ़ाती है।
आंतरिक रूप से माइक्रोसर्विस एसओए को लागू करता है। व्यापक अर्थ में, हम इसे एक SOA एप्लिकेशन के सबसेट के रूप में मान सकते हैं।
नियम और वर्कफ़्लो
निम्नलिखित सिद्धांत हैं जिन्हें एक माइक्रोसैस सर्विस विकसित करते समय ध्यान रखने की आवश्यकता है।
High Cohesion- सभी व्यवसाय मॉडल को जितना संभव हो उतना छोटा व्यापार भाग में उप-विभाजित करने की आवश्यकता है। प्रत्येक सेवा को केवल एक व्यावसायिक कार्य करने के लिए केंद्रित किया जाना चाहिए।
Independent - सभी सेवाओं को प्रकृति में पूर्ण स्टैक होना चाहिए और एक-दूसरे से स्वतंत्र होना चाहिए।
Business Domain Centric - सॉफ्टवेयर व्यवसाय इकाई के अनुसार संशोधित करेगा और टियर आधारित नहीं है।
Automation- परीक्षण तैनाती स्वचालित होगी। न्यूनतम मानव संपर्क शुरू करने की कोशिश करें।
Observable - प्रत्येक सेवा प्रकृति में पूर्ण स्टैक होगी और उन्हें एक उद्यम अनुप्रयोग की तरह स्वतंत्र रूप से तैनात और अवलोकन योग्य होना चाहिए।
टीम प्रबंधन
"दो पिज्जा नियम" एक तरह का नियम है जो एक माइक्रोसेवा विकास टीम में उपस्थित लोगों की संख्या को प्रतिबंधित करता है। इस नियम के अनुसार, एक आवेदन के टीम के सदस्यों की संख्या इतनी कम होनी चाहिए कि उन्हें दो पिज्जा खिलाया जा सके। आम तौर पर, संख्या 8 से अधिक नहीं होनी चाहिए। जैसा कि माइक्रोसर्विस प्रकृति में पूर्ण स्टैक है, टीम प्रकृति में भी पूर्ण स्टैक है। उत्पादकता बढ़ाने के लिए, हमें उस सेवा के लिए आवश्यक सभी प्रकार की विशेषज्ञता के साथ अधिकतम 8 सदस्यों की एक टीम बनाने की आवश्यकता है।
कार्य प्रबंधन
सॉफ्टवेयर विकास जीवन चक्र में टास्क एक महत्वपूर्ण भूमिका है। कार्य की कई छोटी इकाइयों में बड़े पैमाने पर अनुप्रयोग को विकसित किया जा सकता है। हमें विचार करें कि हमें फेसबुक जैसे एक एप्लिकेशन को विकसित करने की आवश्यकता है। फिर, "लॉग इन" कार्यक्षमता को पूरी निर्माण प्रक्रिया के कार्य के रूप में माना जा सकता है। इन कार्यों में से प्रत्येक के लिए प्रगति को अत्यधिक कुशल पेशेवरों के तहत ठीक से निगरानी करने की आवश्यकता है। Agile उद्योगों में अच्छी तरह से ज्ञात प्रक्रिया संरचना है जिसका पालन करना अच्छे कार्य प्रबंधन के साथ है।
अब तक हमने यह जान लिया है कि आधुनिक एमवीसी आर्किटेक्चर के ऊपर माइक्रो सर्विस क्या है और इसकी बुनियादी जरूरतें क्या हैं। इस अध्याय में, हम इस वास्तुकला के विभिन्न तत्वों को जानेंगे जो एक सेवा के लिए समान रूप से महत्वपूर्ण हैं।
सेवाओं की श्रेणियाँ
माइक्रोसर्विस नाम से, हम मानते हैं कि यह एक ऐसी सेवा होगी जो HTTP प्रोटोकॉल से अधिक खपत की जा सकती है, हालांकि हमें यह जानना होगा कि इस वास्तुकला का उपयोग करके किस प्रकार की सेवाओं का निर्माण किया जा सकता है। निम्नलिखित सेवाओं की सूची है जो कि माइक्रोसैस आर्किटेक्चर का उपयोग करके कार्यान्वित की जा सकती है।
Platform as a Service [PaaS]- इस सेवा-उन्मुख वास्तुकला में, मंच को एक उपकरण के रूप में दिया जाता है जिसे व्यावसायिक आवश्यकताओं के अनुसार अनुकूलित किया जा सकता है। Paa मोबाइल एप्लिकेशन विकास में एक महत्वपूर्ण भूमिका निभाता है। PaS का सबसे बड़ा उदाहरण Google App इंजन है, जहाँ Google आपके एप्लिकेशन को बनाने के लिए अलग-अलग उपयोगी प्लेटफ़ॉर्म प्रदान करता है। Paa मूल रूप से डेवलपर्स को एक अंतर्निहित वास्तुकला या बुनियादी ढांचा प्रदान करने के लिए विकसित करता है। यह नाटकीय रूप से कम समय में उच्च स्तर की प्रोग्रामिंग जटिलता को कम करता है। निम्नलिखित Google द्वारा PaaS प्रदान की गई स्नैपशॉट है।
Software as a Service [SaaS]- सेवा के रूप में सॉफ्टवेयर एक सॉफ्टवेयर लाइसेंसिंग व्यवसाय है, जहां सदस्यता के आधार पर सॉफ्टवेयर को केंद्र में होस्ट और लाइसेंस दिया जाता है। सास को मुख्य रूप से ब्राउज़र के माध्यम से एक्सेस किया जा सकता है और यह कई व्यावसायिक वर्टिकल जैसे कि ह्यूमन रिसोर्स मैनेजमेंट (HRM), एंटरप्राइज रिसोर्स प्लानिंग (ERP), कस्टमर रिलेशनशिप मैनेजमेंट (CRM), आदि में एक बहुत ही सामान्य आर्किटेक्चर पैटर्न है, जिसका अनुसरण स्क्रीनशॉट के उदाहरणों से होता है। ओरेकल द्वारा प्रदान किए गए विभिन्न सास।
Infrastructure as a Service [IaaS]- आईटी उद्योगों में इन्फ्रास्ट्रक्चर अच्छी भूमिका निभाता है। क्लाउड कंप्यूटिंग का उपयोग करते हुए, कुछ संगठन अपनी सेवाओं के रूप में वर्चुअल इन्फ्रास्ट्रक्चर प्रदान करते हैं। आईएएएस सॉफ्टवेयर विकास में चपलता, लागत-प्रभावशीलता, सुरक्षा, प्रदर्शन, उत्पादकता आदि लाने के लिए बहुत सहायक है। Amazon EC2 और Microsoft Azure IaaS के सबसे बड़े उदाहरण हैं। निम्न छवि में AWS का उदाहरण दिखाया गया है, जहाँ IaaS के रूप में डेटा केंद्र प्रदान किया गया है।
Data as a Service [DaaS]- सूचना प्रौद्योगिकी डेटा से संबंधित है और उद्योग के कुछ शीर्ष नेताओं का मानना है कि डेटा समाज का नया निर्वाह होगा। डीएएएस एक प्रकार की सेवा है, जहां डेटा को अनुसंधान और विश्लेषण के लिए व्यावसायिक समूह के साथ साझा किया जाता है। डीएएएस डेटा एक्सेस लेयर में सरलता, चपलता और सुरक्षा लाता है। निम्नलिखित Oracle डेटा क्लाउड का एक उदाहरण है, जिसे आपके स्वयं की व्यावसायिक आवश्यकताओं के लिए एक्सेस या लाइसेंस प्राप्त किया जा सकता है।
Back End as a Service [BaaS]- BaaS को MBaaS के रूप में भी जाना जाता है, जिसका अर्थ है कि सेवा के रूप में मोबाइल बैक-एंड। इस प्रकार की सेवा में, अपने स्वयं के व्यावसायिक उपक्रमों के लिए व्यावसायिक इकाइयों को आवेदन का बैकएंड प्रदान किया जाएगा। सभी पुश सूचनाएँ, सोशल नेटवर्किंग सेवाएँ इस प्रकार की सेवाओं के अंतर्गत आती हैं। फेसबुक और ट्विटर प्रसिद्ध BaaS सेवा प्रदाता के उदाहरण हैं।
सुरक्षा
जब ग्राहक डेटा के टन से निपटने की बात आती है, तो सुरक्षा एक महत्वपूर्ण भूमिका निभाती है। सुरक्षा मुद्दा बाजार में उपलब्ध सभी प्रकार की सेवाओं से जुड़ा है। आप जो भी क्लाउड का उपयोग कर रहे हैं - निजी, सार्वजनिक, हाइब्रिड आदि, सुरक्षा सभी स्तरों पर बनाए रखी जानी चाहिए। संपूर्ण सुरक्षा समस्या को मोटे तौर पर निम्नलिखित भागों में विभाजित किया जा सकता है -
Security issue faced by service providers - इस प्रकार की सुरक्षा समस्या का सामना सेवा प्रदाताओं जैसे कि Google, Amazon, आदि द्वारा किया जाता है। सुरक्षा सुरक्षा सुनिश्चित करने के लिए, क्लाइंट की पृष्ठभूमि की जाँच आवश्यक है, विशेष रूप से उन लोगों के लिए जो क्लाउड के मुख्य भाग तक सीधी पहुँच रखते हैं।
Security issue faced by consumers- क्लाउड लागत के अनुकूल है, इसलिए इसे व्यापक रूप से उद्योगों में उपयोग किया जाता है। कुछ संगठन उपयोगकर्ता विवरणों को तृतीय पक्ष डेटा केंद्रों में संग्रहीत करते हैं, और जब भी आवश्यक हो डेटा को खींचते हैं। इसलिए, सुरक्षा स्तरों को बनाए रखना अनिवार्य है, जैसे कि एक ग्राहक का कोई भी निजी डेटा किसी अन्य उपयोगकर्ता को दिखाई नहीं देना चाहिए।
उपर्युक्त सुरक्षा समस्याओं को रोकने के लिए, संगठनों द्वारा उपयोग किए जाने वाले कुछ रक्षात्मक तंत्र निम्नलिखित हैं।
Deterrent Control - साइबर हमले को कम करने के लिए संभावित खतरे को जानें।
Preventive Control - अपने क्लाउड तक पहुंचने के लिए उच्च स्तरीय प्रमाणीकरण नीति बनाए रखें।
Detective Control - अपने उपयोगकर्ताओं की निगरानी करें और किसी भी संभावित जोखिम का पता लगाएं।
Corrective Control - अलग-अलग टीमों के साथ मिलकर काम करें और जासूसी नियंत्रण चरण के दौरान आने वाले मुद्दों को ठीक करें।
सॉफ्टवेयर रचना का अर्थ है अपने सॉफ्टवेयर उत्पाद के निर्माण का तरीका। मूल रूप से यह उच्च स्तरीय सॉफ्टवेयर आर्किटेक्चर आरेख से संबंधित है जहां आपके सॉफ़्टवेयर के विभिन्न मॉड्यूल विशिष्ट व्यावसायिक लक्ष्यों के लिए संवाद करेंगे। इस अध्याय में, हम संगठनों में व्यापक रूप से उपयोग किए जाने वाले विभिन्न सॉफ़्टवेयर संरचना पैटर्न के बारे में जानेंगे। माइक्रोसैस सर्विस में, हम प्रत्येक फ़ंक्शन को एक प्रक्रिया में विभाजित करते हैं। इनमें से प्रत्येक सेवा प्रकृति में स्वतंत्र और पूर्ण स्टैक होगी।
कार्यात्मक अपघटन आपके माइक्रोसर्विस के निर्माण में महत्वपूर्ण भूमिका निभाता है। यह आपके आवेदन में चपलता, लचीलापन और स्केलेबिलिटी प्रदान करता है।
एग्रीगेटर पैटर्न
एग्रीगेटर पैटर्न सबसे सरल वेब पैटर्न है जो कि एक माइक्रोसैस सर्विस को विकसित करते समय लागू किया जा सकता है। इस रचना पैटर्न में, एक साधारण वेब मॉड्यूल एक लोड बैलेंसर के रूप में कार्य करेगा, जिसका अर्थ है कि यह आवश्यकताओं के अनुसार विभिन्न सेवाओं को कॉल करेगा। निम्नलिखित एक आरेख है जो एग्रीगेटर डिज़ाइन के साथ एक सरल माइक्रोसेवर वेब ऐप का चित्रण करता है। जैसा कि निम्नलिखित छवि में देखा गया है, "एग्रीगेटर" एक के बाद एक विभिन्न सेवाओं को कॉल करने के लिए जिम्मेदार है। यदि हमें सेवा ए, बी और सी के परिणामों पर किसी भी व्यावसायिक तर्क को लागू करने की आवश्यकता है, तो हम एग्रीगेटर में ही व्यापार तर्क को लागू कर सकते हैं।
एक एग्रीगेटर को फिर से बाहरी दुनिया में एक और सेवा के रूप में उजागर किया जा सकता है, जिसे आवश्यकता पड़ने पर दूसरों द्वारा उपभोग किया जा सकता है। एग्रीगेटर पैटर्न वेब सेवा विकसित करते समय, हमें यह ध्यान रखना होगा कि हमारी प्रत्येक सेवा ए, बी और सी की अपनी कैशिंग परतें होनी चाहिए और यह प्रकृति में पूर्ण स्टैक होनी चाहिए।
प्रॉक्सी पैटर्न
प्रॉक्सी microservice पैटर्न एग्रीगेटर मॉडल की एक भिन्नता है। इस मॉडल में हम एकत्रीकरण मॉड्यूल के बजाय प्रॉक्सी मॉड्यूल का उपयोग करेंगे। प्रॉक्सी सेवा अलग-अलग सेवाओं को अलग-अलग कह सकती है।
प्रॉक्सी पैटर्न में, हम डंप प्रॉक्सी परत प्रदान करके एक स्तर की अतिरिक्त सुरक्षा का निर्माण कर सकते हैं। यह परत इंटरफ़ेस के समान कार्य करती है।
जंजीर पैटर्न
जैसा कि नाम से पता चलता है, इस प्रकार की रचना पैटर्न श्रृंखला संरचना का पालन करेगी। यहां, हम क्लाइंट और सर्विस लेयर के बीच में कुछ भी उपयोग नहीं करेंगे। इसके बजाय, हम ग्राहक को सेवाओं के साथ सीधे संवाद करने की अनुमति देंगे और सभी सेवाओं को इस तरह से व्यवस्थित किया जाएगा कि एक सेवा का आउटपुट अगली सेवा का इनपुट होगा। निम्नलिखित छवि एक विशिष्ट जंजीर पैटर्न microservice से पता चलता है।
इस आर्किटेक्चर का एक बड़ा दोष यह है कि क्लाइंट पूरी प्रक्रिया पूरी होने तक अवरुद्ध रहेगा। इस प्रकार, श्रृंखला की लंबाई को यथासंभव कम रखने के लिए यह अत्यधिक अनुशंसित है।
शाखा माइक्रोसिस्ट सेवा पैटर्न
शाखा माइक्रोसर्वर एग्रीगेटर पैटर्न और चेन पैटर्न का विस्तारित संस्करण है। इस डिजाइन पैटर्न में, ग्राहक सेवा के साथ सीधे संवाद कर सकता है। साथ ही, एक सेवा एक समय में एक से अधिक सेवाओं के साथ संचार कर सकती है। निम्नलिखित शाखा माइक्रोसर्विस का आरेखीय प्रतिनिधित्व है।
शाखा माइक्रोसॉफ़्ट पैटर्न, डेवलपर को गतिशील रूप से सेवा कॉल को कॉन्फ़िगर करने की अनुमति देता है। सभी सेवा कॉल समवर्ती तरीके से होंगी, जिसका अर्थ है कि सेवा ए सेवा बी और सी को एक साथ कह सकती है।
साझा संसाधन पैटर्न
साझा संसाधन पैटर्न वास्तव में पहले उल्लिखित सभी प्रकार के पैटर्न का एक समूह है। इस पैटर्न में, क्लाइंट या लोड बैलेंसर आवश्यक होने पर प्रत्येक सेवा से सीधे संवाद करेंगे। यह सबसे प्रभावी डिजाइनिंग पैटर्न है जिसका अधिकांश संगठनों में व्यापक रूप से पालन किया जाता है। निम्नलिखित साझा संसाधन डिजाइन पैटर्न का एक आरेखीय प्रतिनिधित्व है।
इस अध्याय में, हम SOA आर्किटेक्चर के साथ एक CRUD- आधारित एप्लिकेशन विकसित करेंगे। बाद के अध्यायों में बाद में, हम इस सेवा को माइक्रोसैस सर्विस में तोड़ देंगे और हम SOA और माइक्रोकवर्क आर्किटेक्चर के बीच बुनियादी अंतर को जानेंगे।
सिस्टम कॉन्फ़िगरेशन और सेटअप
इस खंड में, हम एक नमूना CRUD अनुप्रयोग का निर्माण करेंगे, जो जब भी हमारी सेवा को कॉल करेगा, प्रतिक्रिया के रूप में JSON ऑब्जेक्ट लौटाएगा। हम उसी को विकसित करने के लिए जर्सी ढांचे का उपयोग करेंगे। निम्नलिखित आपके स्थानीय सिस्टम वातावरण को सेट करने के लिए चरण हैं।
एक CRUD अनुप्रयोग का विकास करना
Step 1- हम नेटबीन्स को विकास आईडीई के रूप में उपयोग करेंगे। कृपया नेटबींस की आधिकारिक वेबसाइट पर उपलब्ध नवीनतम संस्करण को डाउनलोड करें और इंस्टॉल करेंhttps://netbeans.org/downloads/।
Step 2- अपना नेटबीन्स आईडीई खोलें। "फ़ाइल -> नई परियोजना" पर जाएं। निम्न स्क्रीनशॉट पॉप अप करता है। एक श्रेणी के रूप में "मावेन" चुनें और एक परियोजना के रूप में "आर्कटाइप से प्रोजेक्ट" चुनें और अगला हिट करें।
यह आपकी पहली Maven परियोजना और Restful Web Service बनाने के लिए सभी आवश्यक जार फ़ाइलों को डाउनलोड करेगा।
Step 3- पिछले चरण में अगला बटन मारने पर, निम्न स्क्रीनशॉट दिखाई देता है। यहां, आपको मावेन आर्केचे को निर्दिष्ट करना होगा।
खोज बॉक्स में, "जर्सी-आर्कटाइप-वेबैप (2.16)" के लिए खोजें और "पुराने दिखाएं" चेकबॉक्स की जांच करें।
Step 4- एक बार जब आप उसी का चयन कर लेते हैं, तो आपको निम्न स्क्रीन पर भेज दिया जाएगा। सूची से पसंदीदा जार का चयन करें और जारी रखने के लिए अगला मारा।
Step 5- इस चरण में, आपको अपनी परियोजना का नाम और उसकी ग्रुप आईडी के साथ-साथ पैकेज विवरण भी प्रदान करना होगा। यह सब जानकारी प्रदान करने के बाद, जारी रखने के लिए समाप्त करें को हिट करें।
Step 6- आप अपने कार्यक्षेत्र सेटअप के साथ कर रहे हैं। परियोजना निर्देशिका निम्नलिखित की तरह दिखाई देगी।
अपने "निर्भरताएँ" फ़ोल्डर की जाँच करें और आप पाएंगे कि मावेन ने इस परियोजना के लिए सभी आवश्यक जार फ़ाइलों को स्वचालित रूप से डाउनलोड किया है।
Step 7- आपका कार्यक्षेत्र सेट है और आप कोडिंग से शुरुआत कर सकते हैं। आगे बढ़ें और निम्न स्क्रीनशॉट में वर्णित चार कक्षाएं और पैकेज बनाएं। आप पा सकते हैं MyResource.java पहले से ही मावेन द्वारा बनाया गया है, क्योंकि मावेन यह पता लगाने के लिए पर्याप्त स्मार्ट है कि आप अपनी खुद की वेब सेवा बनाने जा रहे हैं।
Step 8 - एक बार उपरोक्त कदम के साथ, हम अपने POJO वर्ग का निर्माण करेंगे जो कि UserProfile.java निम्नानुसार है।
package com.tutorialspoint.userprofile.Model;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement
public class UserProfile {
private long ProId;
private String FName;
private String LName;
private String Add;
public UserProfile(){}
public UserProfile(long Proid, String Fname, String Lname,String Add) {
this.ProId = Proid;
this.FName = Fname;
this.LName = Lname;
this.Add = Add;
}
public long getProId() {
return ProId;
}
public void setProId(long ProId) {
this.ProId = ProId;
}
public String getFName() {
return FName;
}
public void setFName(String FName) {
this.FName = FName;
}
public String getLName() {
return LName;
}
public void setLName(String LName) {
this.LName = LName;
}
public String getAdd() {
return Add;
}
public void setAdd(String Add) {
this.Add = Add;
}
}
Step 9- अब हम अपना डेटाबेस क्लास बनाएंगे। चूंकि यह शिक्षण सामग्री का एक हिस्सा है, हम अपने डेटाबेस के रूप में किसी भी डीबी का उपयोग नहीं करेंगे। हम अपनी अस्थायी मेमोरी के रूप में काम करने के लिए इनबिल्ट जावा मेमोरी का उपयोग करेंगे। जैसा कि आप कोड के निम्नलिखित सेट में देख सकते हैं, हम MAP को हमारे डेटाबेस के रूप में उपयोग करेंगे। सभी वेब सेवा ऑपरेशन जो हम करते हैं, हम कक्षा में परिभाषित इस एमएपी पर काम करेंगे।
package com.tutorialspoint.userprofile.DAO;
import com.tutorialspoint.userprofile.Model.UserProfile;
import java.util.HashMap;
import java.util.Map;
public class DatabaseClass {
private static Map<Long,UserProfile> messages = new HashMap<Long,UserProfile>();
public static Map<Long,UserProfile> getUsers() {
return messages;
// Each time this method will return entire map as an instance of database
}
}
Step 10- अब हम अपनी सर्विस क्लास बनाते हैं। आगे बढ़ो और "ProfileService.java" वर्ग में कोड के निम्नलिखित सेट को कॉपी करें। यह वह वर्ग है जहां हम अपनी सभी वेब सेवा विधियों की घोषणा करेंगे, जिन्हें बाहरी दुनिया के लिए उजागर किया जाना है। हमें अपने डेटाबेसक्लास का एक संदर्भ बनाने की जरूरत है ताकि हमारे अस्थायी डेटाबेस को इस वर्ग में पहुँचा जा सके।
package com.tutorialspoint.userprofile.service;
import com.tutorialspoint.userprofile.DAO.DatabaseClass;
import com.tutorialspoint.userprofile.Model.UserProfile;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
public class ProfileService {
private Map<Long,UserProfile> Userprofiles = DatabaseClass.getUsers();
// Creating some predefine profile and populating the same in the map
public ProfileService() {
UserProfile m1 = new UserProfile(1L,"Tutorials1","Point1","TutorialsPoint.com");
UserProfile m2 = new UserProfile(2L,"Tutorials2","Point2","TutorialsPoint.com2");
UserProfile m3 = new UserProfile(3L,"Tutorials3","Point3","TutorialsPoint.com3");
UserProfile m4 = new UserProfile(4L,"Tutorials4","Point4","TutorialsPoint.com4");
Userprofiles.put(1L, m1);
Userprofiles.put(2L, m2);
Userprofiles.put(1L, m3);
Userprofiles.put(2L, m4);
}
//Method to fetch all profile
public List<UserProfile> getAllProfile() {
List<UserProfile> list = new ArrayList<UserProfile>(Userprofiles.values());
return list;
} // Method to fetch only one profile depending on the ID provided
public UserProfile getProfile(long id) {
return Userprofiles.get(id);
} //Method to add profile
public UserProfile addProfile(UserProfile UserProfile) {
UserProfile.setProId(Userprofiles.size()+1);
Userprofiles.put(UserProfile.getProId(), UserProfile);
return UserProfile;
} //method to update Profile
public UserProfile UpdateProfile(UserProfile UserProfile) {
if(UserProfile.getProId()<=0) {
return null;
} else {
Userprofiles.put(UserProfile.getProId(), UserProfile);
return UserProfile;
}
} //method to delete profile
public void RemoveProfile(long Id) {
Userprofiles.remove(Id);
}
}
Step 11 - इस चरण में, हम अपना रिसोर्स क्लास बनाएंगे जो यूआरएल के साथ जुड़ा होगा और इसी सेवा को कॉल किया जाएगा।
package com.tutorialspoint.userprofile.Resource;
import com.tutorialspoint.userprofile.Model.UserProfile;
import com.tutorialspoint.userprofile.service.ProfileService;
import java.util.List;
import javax.ws.rs.Consumes;
import javax.ws.rs.DELETE;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.PUT;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
@Path("/Profile")
@Consumes(MediaType.APPLICATION_XML)
@Produces(MediaType.APPLICATION_XML)
public class ProfileResource {
ProfileService messageService = new ProfileService();
@GET
public List<UserProfile> getProfile() {
return messageService.getAllProfile();
}
@GET
@Path("/{ProID}")
public UserProfile getProfile(@PathParam("ProID")long Id) {
return messageService.getProfile(Id);
}
@POST
public UserProfile addProfile(UserProfile profile) {
return messageService.addProfile(profile);
}
@PUT
@Path("/{proID}")
public UserProfile UpdateProfile(@PathParam("proID")long Id,UserProfile UserProfile) {
UserProfile.setProId(Id);
return messageService.UpdateProfile(UserProfile);
}
@DELETE
@Path("/{ProID}")
public void deleteProfile(@PathParam("ProID")long Id) {
messageService.RemoveProfile(Id);
}
}
Step 12- स्वच्छ परियोजना का निर्माण करें और इसे चलाएं। यदि सबकुछ ठीक हो जाता है, तो आपको एक्सेस करते समय ब्राउज़र में निम्न आउटपुट प्राप्त करना चाहिएhttp://localhost:8080/UserProfile/webapi/Profile” यूआरएल।
आप देख सकते हैं कि विभिन्न प्रविष्टियाँ XML प्रतिनिधित्व का उपयोग करके पॉपुलेटेड हैं।
उचित विधि URL को लागू करके पोस्टमैन का उपयोग करके विभिन्न विधि का परीक्षण किया जा सकता है।
@GET method - निम्न स्क्रीनशॉट दर्शाता है कि हम अनुरोध प्राप्त करने के लिए वांछित परिणाम कैसे प्राप्त कर सकते हैं, जो सभी उपयोगकर्ता विवरणों को वापस करता है।
@POST- हमारी पोस्ट विधि का परीक्षण करने के लिए निम्नलिखित अनुरोध का उपयोग किया जा सकता है। ध्यान दें कि कैसे proId स्वचालित रूप से उत्पन्न किया गया है।
@PUT- यह विधि प्रविष्टियों को अपडेट करेगी। निम्न स्क्रीनशॉट दर्शाता है कि जर्सी अनुरोध URL से कैसे लेता है और उसी उपयोगकर्ता प्रोफ़ाइल उत्तर को अपडेट करता है।
उसी तरह, आप अपनी वेब सेवाओं में उपलब्ध अन्य तरीकों की जाँच कर सकते हैं।
पिछले अनुभाग में, हमने एक सेवा विकसित की है जो CRUD कार्यक्षमता को उजागर करेगी। अब जब भी हम अपने एप्लिकेशन में इस सेवा को लागू करने का प्रयास करते हैं, तो हमें इस एप्लिकेशन का एक क्लाइंट बनाना होगा और इसे हमारे एप्लिकेशन में संलग्न करना होगा। इस अध्याय में, हम सीखेंगे कि माइक्रोसैस सर्विस की अवधारणा का उपयोग करके इस कार्यक्षमता का निर्माण कैसे करें। उपरोक्त चरणों का उपयोग करके निर्मित हमारे आवेदन का एक आरेखीय प्रतिनिधित्व निम्नलिखित है।
अभिनेता को हमारी सेवा का प्रवेश बिंदु होना चाहिए। इस मामले में "ProfileResource.java" एक अभिनेता की जिम्मेदारी निभाता है। यह वर्ग अलग-अलग ऑपरेशन करने के लिए विभिन्न तरीकों को कॉल करेगा जैसे कि ऐड, अपडेट और डिलीट।
सीआरयूडी अनुप्रयोग का अपघटन
माइक्रोसर्विस के मुख्य सिद्धांत के अनुसार, हमें प्रत्येक मॉड्यूल के लिए केवल एक व्यवसाय कार्य करने की आवश्यकता है, इसलिए सभी चार CRUD कार्यात्मकताओं के लिए एक अभिनेता को जिम्मेदार नहीं होना चाहिए। निम्नलिखित उदाहरण पर विचार करें जहां हमने कुछ नई भूमिकाएं पेश की हैं, ताकि यह आपके लिए वैचारिक रूप से स्पष्ट हो जाए कि माइक्रोसैस एसओए का एक वास्तुशिल्प प्रतिनिधित्व है।
"मुख्य उपयोगकर्ता" वह उपयोगकर्ता है जो किसी की जरूरतों को पूरा करने के लिए "एप्लिकेशन कंट्रोलर" के साथ संचार करता है। "एप्लिकेशन कंट्रोलर" वह है जो अंतिम उपयोगकर्ता के अनुरोध के आधार पर अलग-अलग "संसाधन प्रबंधक" कहता है। "संसाधन प्रबंधक" वह कार्य करता है जिसे करने की आवश्यकता होती है। आइए आवेदन की विभिन्न इकाइयों की विभिन्न भूमिकाओं पर एक त्वरित नज़र डालें।
End User/Main Users - आवेदन नियंत्रक के लिए कुछ संसाधनों के लिए अनुरोध।
Application - अनुरोध प्राप्त करता है और विशिष्ट संसाधन प्रबंधक के लिए आगे की ओर।
Resource Manager - उपयोगकर्ताओं को अपडेट करने, हटाने और जोड़ने का वास्तविक काम करता है।
देखें कि विभिन्न वर्गों के बीच एक वर्ग की कुल जिम्मेदारी कैसे वितरित की जाती है।
इस अध्याय में, हम एक microservice एप्लिकेशन का निर्माण करेंगे जो विभिन्न उपलब्ध सेवाओं का उपभोग करेगा। हम सभी जानते हैं कि माइक्रोसर्विस एक एप्लिकेशन बनाने के लिए एक लागत प्रभावी तरीका नहीं है, क्योंकि हम जो भी सेवा बनाते हैं, वह प्रकृति में पूर्ण रूप से स्टैक होगी। स्थानीय परिवेश में माइक्रोसर्विस का निर्माण करने के लिए उच्च-एंड सिस्टम कॉन्फ़िगरेशन की आवश्यकता होगी, क्योंकि आपको सर्वर के चार उदाहरणों को चालू रखने की आवश्यकता होती है, ताकि एक समय में इसका उपभोग किया जा सके। हमारे पहले कभी microservice का निर्माण करने के लिए, हम उपलब्ध SOA समापन बिंदुओं में से कुछ का उपयोग करेंगे और हम अपने आवेदन में उसी का उपभोग करेंगे।
सिस्टम कॉन्फ़िगरेशन और सेटअप
बिल्ड चरण के लिए आगे जाने से पहले, अपने सिस्टम को तदनुसार तैयार करें। आपको कुछ सार्वजनिक वेब सेवाओं की आवश्यकता होगी। इसके लिए आप आसानी से google कर सकते हैं। यदि आप SOAP वेब सेवा का उपभोग करना चाहते हैं, तो आपको एक WSDL फ़ाइल मिलेगी और वहाँ से आपको विशिष्ट वेब सेवा का उपभोग करने की आवश्यकता है। REST सेवा के लिए, आपको उसी का उपभोग करने के लिए केवल एक लिंक की आवश्यकता होगी। इस उदाहरण में, आप एक अनुप्रयोग में तीन अलग-अलग वेब सेवाओं "SOAP", "REST" और "कस्टम" को जाम करेंगे।
अनुप्रयोग वास्तुकला
आप microservice कार्यान्वयन योजना का उपयोग करके एक जावा एप्लिकेशन बनाएंगे। आप एक कस्टम सेवा बनाएंगे और इस सेवा का आउटपुट अन्य सेवाओं के लिए एक इनपुट के रूप में काम करेगा।
निम्नलिखित एक microservice आवेदन विकसित करने के लिए पालन करने के लिए कदम हैं।
Step 1: Client creation for SOAP service- वेब सेवा सीखने के लिए कई मुफ्त वेब एपीआई उपलब्ध हैं। इस ट्यूटोरियल के उद्देश्य के लिए, “जियोआईपी सेवा” का उपयोग करें।http://www.webservicex.net/.”WSDL फ़ाइल उनकी वेबसाइट “ webservicex.net ” पर निम्नलिखित लिंक में दी गई है । इस डब्लूएसडीएल फ़ाइल से क्लाइंट को उत्पन्न करने के लिए, आपको केवल अपने टर्मिनल में निम्न कमांड को चलाने की आवश्यकता है।
wsimport http://www.webservicex.net/geoipservice.asmx?WSDL
यह कमांड "एसईआई" नामक एक फ़ोल्डर के तहत सभी आवश्यक क्लाइंट फाइलें उत्पन्न करेगा, जिसे सेवा अंत बिंदु इंटरफ़ेस के नाम पर रखा गया है।
Step 2: Create your custom web service- इस ट्यूटोरियल में पहले चरण में बताई गई समान प्रक्रिया का पालन करें और "CustomRest" नाम से एक मावेन-आधारित REST एपी बनाएं। एक बार पूरा होने पर, आपको "MyResource.java" नामक एक वर्ग मिलेगा। आगे बढ़ो और निम्नलिखित कोड का उपयोग करके इस वर्ग को अपडेट करें।
package com.tutorialspoint.customrest;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
@Path("myresource")
public class MyResource {
@GET
@Produces(MediaType.TEXT_PLAIN)
public String getIt() {
return "IND|INDIA|27.7.65.215";
}
}
सब कुछ पूरा हो जाने के बाद, आगे बढ़ें और सर्वर पर इस एप्लिकेशन को चलाएं। आपको ब्राउज़र में निम्न आउटपुट प्राप्त करना चाहिए।
यह वेब सर्वर है, जो एक स्ट्रिंग ऑब्जेक्ट को कॉल करने के बाद लौटाता है। यह इनपुट सेवा है जो रिकॉर्ड प्रदान करने के लिए अन्य एप्लिकेशन द्वारा उपभोग किए जा सकने वाले इनपुट प्रदान करती है।
Step 3: Configure another Rest API- इस चरण में, services.groupkt.com पर उपलब्ध एक अन्य वेब सेवा का उपभोग करें । जब यह JSON ऑब्जेक्ट लौटाया जाएगा।
Step 4: Create JAVA application - "नई परियोजना" -> "जावा परियोजना" का चयन करके एक सामान्य जावा एप्लिकेशन बनाएं और निम्न स्क्रीनशॉट में दिखाए अनुसार खत्म करें।
Step 5: Add the SOAP client- चरण 1 में, आपने SOAP वेब सेवा के लिए क्लाइंट फ़ाइल बनाई है। आगे बढ़ो और इन क्लाइंट फ़ाइलों को अपनी वर्तमान परियोजना में जोड़ें। क्लाइंट फ़ाइलों के सफल जोड़ के बाद, आपकी एप्लिकेशन निर्देशिका निम्नलिखित दिखाई देगी।
Step 6: Create your main app- अपना मुख्य वर्ग बनाएं जहां आप इन तीनों वेब सेवाओं का उपभोग करेंगे। स्रोत प्रोजेक्ट पर राइट-क्लिक करें और "MicroServiceInAction.java" नामक एक नया वर्ग बनाएं। अगला काम इसके लिए विभिन्न वेब सेवाओं को कॉल करना है।
Step 7: Call your custom web service - इसके लिए, अपनी स्वयं की सेवा को लागू करने के लिए कोडों के निम्नलिखित सेट को जोड़कर आगे बढ़ें।
try {
url = new URL("http://localhost:8080/CustomRest/webapi/myresource");
conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
conn.setRequestProperty("Accept", "application/json");
if (conn.getResponseCode() != 200) {
throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode());
}
BufferedReader br = new BufferedReader(new InputStreamReader(
(conn.getInputStream())));
while ((output = br.readLine()) != null) {
inputToOtherService = output;
}
conn.disconnect();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
Step 8: Consume SOAP Services- आपने अपनी क्लाइंट फ़ाइल तैयार कर ली है, लेकिन आपको यह नहीं पता कि उस पूरे पैकेज में किस विधि को बुलाया जाना चाहिए? इसके लिए, आपको फिर से डब्ल्यूएसडीएल को संदर्भित करने की आवश्यकता है, जिसका उपयोग आपने अपने क्लाइंट फ़ाइलों को उत्पन्न करने के लिए किया था। प्रत्येक WSDL फ़ाइल में इस टैग के लिए एक "wsdl: सेवा" टैग होना चाहिए। यह उस वेब सेवा का आपका प्रवेश बिंदु होना चाहिए। इस एप्लिकेशन का सेवा समापन बिंदु निम्नलिखित है।
अब आपको अपने आवेदन में इस सेवा को लागू करने की आवश्यकता है। निम्नलिखित जावा कोड का सेट है जिसे आपको अपनी SOAP वेब सेवा को लागू करने की आवश्यकता है।
GeoIPService newGeoIPService = new GeoIPService();
GeoIPServiceSoap newGeoIPServiceSoap = newGeoIPService.getGeoIPServiceSoap();
GeoIP newGeoIP = newGeoIPServiceSoap.getGeoIP(Ipaddress);
// Ipaddress is output of our own web service.
System.out.println("Country Name from SOAP Webserivce ---"+newGeoIP.getCountryName());
Step 9: Consume REST web service- अब तक दो सेवाओं का उपभोग किया गया है। इस चरण में, कस्टम URL के साथ एक और REST वेब सेवा आपकी कस्टम वेब सेवा की मदद से खपत की जाएगी। ऐसा करने के लिए कोड के निम्नलिखित सेट का उपयोग करें।
String url1="http://services.groupkt.com/country/get/iso3code/";//customizing the Url
url1 = url1.concat(countryCode);
try {
URL url = new URL(url1);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
conn.setRequestProperty("Accept", "application/json");
if (conn.getResponseCode() != 200) {
throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode());
}
BufferedReader br = new BufferedReader(new InputStreamReader(
(conn.getInputStream())));
while ((output = br.readLine()) != null) {
System.out.println(output);
}
conn.disconnect();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
Step 10: Consume all services - आपकी "CustomRest" वेब सेवा को ध्यान में रखते हुए और आप इंटरनेट से जुड़े हैं, यदि सब कुछ सफलतापूर्वक पूरा हो गया है, तो आपका समेकित मुख्य वर्ग होना चाहिए।
package microserviceinaction;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.StringTokenizer;
import net.webservicex.GeoIP;
import net.webservicex.GeoIPService;
import net.webservicex.GeoIPServiceSoap;
public class MicroServiceInAction {
static URL url;
static HttpURLConnection conn;
static String output;
static String inputToOtherService;
static String countryCode;
static String ipAddress;
static String CountryName;
public static void main(String[] args) {
//consuming of your own web service
try {
url = new URL("http://localhost:8080/CustomRest/webapi/myresource");
conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
conn.setRequestProperty("Accept", "application/json");
if (conn.getResponseCode() != 200) {
throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode());
}
BufferedReader br = new BufferedReader(new InputStreamReader(
(conn.getInputStream())));
while ((output = br.readLine()) != null) {
inputToOtherService = output;
}
conn.disconnect();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
//Fetching IP address from the String and other information
StringTokenizer st = new StringTokenizer(inputToOtherService);
countryCode = st.nextToken("|");
CountryName = st.nextToken("|");
ipAddress = st.nextToken("|");
// Call to SOAP web service with output of your web service---
// getting the location of our given IP address
String Ipaddress = ipAddress;
GeoIPService newGeoIPService = new GeoIPService();
GeoIPServiceSoap newGeoIPServiceSoap = newGeoIPService.getGeoIPServiceSoap();
GeoIP newGeoIP = newGeoIPServiceSoap.getGeoIP(Ipaddress);
System.out.println("Country Name from SOAP Webservice ---"+newGeoIP.getCountryName());
// Call to REST API --to get all the details of our country
String url1 = "http://services.groupkt.com/country/get/iso3code/"; //customizing the Url
url1 = url1.concat(countryCode);
try {
URL url = new URL(url1);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("GET");
conn.setRequestProperty("Accept", "application/json");
if (conn.getResponseCode() != 200) {
throw new RuntimeException("Failed : HTTP error code : " + conn.getResponseCode());
}
BufferedReader br = new BufferedReader(new InputStreamReader(
(conn.getInputStream())));
while ((output = br.readLine()) != null) {
System.out.println(output);
}
conn.disconnect();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
एक बार जब आप इस फ़ाइल को चलाते हैं, तो आपको कंसोल में निम्न आउटपुट दिखाई देगा। आपने अपना पहला माइक्रोसेवा एप्लिकेशन सफलतापूर्वक विकसित कर लिया है।