MuleSoft - त्वरित गाइड
ईएसबी का मतलब है Enterprise Service Busजो मूल रूप से बस जैसे बुनियादी ढांचे पर एक साथ विभिन्न अनुप्रयोगों को एकीकृत करने के लिए एक मिडलवेयर टूल है। मौलिक रूप से, यह एक वास्तुकला है जिसे एकीकृत अनुप्रयोगों के बीच काम करने का एक समान साधन प्रदान करने के लिए डिज़ाइन किया गया है। इस तरह, ईएसबी वास्तुकला की मदद से हम विभिन्न अनुप्रयोगों को एक संचार बस के माध्यम से जोड़ सकते हैं और उन्हें एक दूसरे पर निर्भर किए बिना संवाद करने में सक्षम कर सकते हैं।
ईएसबी को लागू करना
ESB आर्किटेक्चर का मुख्य फोकस सिस्टम को एक-दूसरे से अलग करना है और उन्हें स्थिर और नियंत्रणीय तरीके से संवाद करने की अनुमति देता है। ईएसबी के कार्यान्वयन की मदद से किया जा सकता है‘Bus’ तथा ‘Adapter’ निम्नलिखित तरीके से -
"बस" की अवधारणा, जो जेएमएस या एएमक्यूपी जैसे संदेश सर्वर के माध्यम से प्राप्त की जाती है, का उपयोग एक दूसरे के लिए विभिन्न अनुप्रयोगों को डिकूप करने के लिए किया जाता है।
"एडेप्टर" की अवधारणा, बैकएंड एप्लिकेशन के साथ संचार करने और एप्लिकेशन प्रारूप से बस प्रारूप में डेटा बदलने के लिए जिम्मेदार है, अनुप्रयोगों और बस के बीच उपयोग किया जाता है।
बस के माध्यम से एक अनुप्रयोग से दूसरे में जाने वाला डेटा या संदेश एक कैनोनिकल प्रारूप में है जिसका अर्थ है कि एक सुसंगत संदेश प्रारूप होगा।
एडेप्टर सुरक्षा, निगरानी, त्रुटि से निपटने और संदेश रूटिंग प्रबंधन जैसी अन्य गतिविधियाँ भी कर सकता है।
ईएसबी के मार्गदर्शक सिद्धांत
इन सिद्धांतों को हम मुख्य एकीकरण सिद्धांत कह सकते हैं। वे इस प्रकार हैं -
Orchestration - डेटा और प्रक्रिया के बीच सिंक्रनाइज़ेशन प्राप्त करने के लिए दो या अधिक सेवाओं का एकीकरण।
Transformation - विशिष्ट प्रारूप को लागू करने के लिए विहित प्रारूप से डेटा को बदलना।
Transportation - एफ़टीपी, एचटीटीपी, जेएमएस, आदि जैसे स्वरूपों के बीच प्रोटोकॉल बातचीत को संभालना।
Mediation - एक सेवा के कई संस्करणों का समर्थन करने के लिए कई इंटरफेस प्रदान करना।
Non-functional consistency - लेनदेन और सुरक्षा के प्रबंधन के लिए भी तंत्र प्रदान करना।
ईएसबी की जरूरत
ईएसबी वास्तुकला हमें विभिन्न अनुप्रयोगों को एकीकृत करने में सक्षम बनाता है जहां प्रत्येक एप्लिकेशन इसके माध्यम से संचार कर सकता है। ESB का उपयोग करने के बारे में कुछ दिशानिर्देश निम्नलिखित हैं -
Integrating two or more applications - दो या दो से अधिक सेवाओं या अनुप्रयोगों को एकीकृत करने की आवश्यकता होने पर ईएसबी वास्तुकला का उपयोग फायदेमंद होता है।
Integration of more applications in future - मान लीजिए अगर हम भविष्य में और अधिक सेवाएँ या एप्लिकेशन जोड़ना चाहते हैं, तो इसे आसानी से ESB आर्किटेक्चर की मदद से किया जा सकता है।
Using multiple protocols - अगर हमें HTTP, FTP, JMS आदि जैसे कई प्रोटोकॉल का उपयोग करने की आवश्यकता है, तो ESB सही विकल्प है।
Message routing - यदि हम संदेश सामग्री और अन्य समान मापदंडों के आधार पर संदेश मार्ग की आवश्यकता हो तो हम ईएसबी का उपयोग कर सकते हैं।
Composition and consumption - अगर हम रचना और उपभोग के लिए सेवाओं को प्रकाशित करना चाहते हैं तो ESB का उपयोग किया जा सकता है।
पी 2 पी एकीकरण बनाम ईएसबी एकीकरण
अनुप्रयोगों की संख्या में वृद्धि के साथ, डेवलपर्स के सामने एक बड़ा सवाल यह था कि विभिन्न अनुप्रयोगों को कैसे जोड़ा जाए? स्थिति को विभिन्न अनुप्रयोगों के बीच एक कनेक्शन को हाथ से कोड करके नियंत्रित किया गया था। यह कहा जाता हैpoint-to-point integration।
Rigidityपॉइंट-टू-पॉइंट इंटीग्रेशन का सबसे स्पष्ट दोष है। कनेक्शन और इंटरफेस की बढ़ती संख्या के साथ जटिलता बढ़ जाती है। P-2-P एकीकरण के नुकसान हमें ईएसबी एकीकरण की ओर ले जाते हैं।
ESB अनुप्रयोग एकीकरण के लिए अधिक लचीला दृष्टिकोण है। यह असतत पुन: प्रयोज्य क्षमताओं के एक सेट के रूप में प्रत्येक अनुप्रयोग कार्यक्षमता को संकुचित और उजागर करता है। कोई भी एप्लिकेशन सीधे अन्य के साथ एकीकृत नहीं होता है, इसके बजाय वे एक ईएसबी के माध्यम से एकीकृत करते हैं जैसा कि नीचे दिखाया गया है -
एकीकरण के प्रबंधन के लिए, ESB के निम्नलिखित दो घटक हैं -
Service Registry- Mule ESB के पास सर्विस रजिस्ट्री / रिपॉजिटरी है जहां ESB में उजागर की गई सभी सेवाएँ प्रकाशित और पंजीकृत हैं। यह एक खोज के बिंदु के रूप में कार्य करता है जहाँ से व्यक्ति अन्य अनुप्रयोगों की सेवाओं और क्षमताओं का उपभोग कर सकता है।
Centralized Administration - जैसा कि नाम से स्पष्ट है, यह ईएसबी के अंदर होने वाली अंतःक्रियाओं के प्रदर्शन के लेन-देन के प्रवाह का एक दृश्य प्रदान करता है।
ESB Functionality- VETRO संक्षिप्त नाम आमतौर पर ESB की कार्यक्षमता को सारांशित करने के लिए उपयोग किया जाता है। यह इस प्रकार है -
V(मान्य) - जैसा कि नाम से ही स्पष्ट है, यह स्कीमा सत्यापन को मान्य करता है। इसके लिए एक मान्य पार्सर और अप-टू-डेट स्कीमा की आवश्यकता होती है। एक उदाहरण एक XML दस्तावेज़ है जो अप-टू-डेट स्कीमा की पुष्टि करता है।
E(एनरिच) - यह एक संदेश में अतिरिक्त डेटा जोड़ता है। उद्देश्य लक्ष्य सेवा के लिए संदेश को अधिक सार्थक और उपयोगी बनाना है।
T(ट्रांसफ़ॉर्म) - यह डेटा संरचना को कैनोनिकल फॉर्मेट या कैनोनिकल फॉर्मेट से परिवर्तित करता है। उदाहरण तारीख / समय, मुद्रा आदि के रूपांतरण हैं।
R(रूटिंग) - यह संदेश को रूट करेगा और सेवा के समापन बिंदु के द्वारपाल के रूप में कार्य करेगा।
O(ऑपरेट) - इस फ़ंक्शन का मुख्य काम लक्ष्य सेवा को लागू करना या लक्ष्य ऐप के साथ सहभागिता करना है। वे बैकेंड पर दौड़ते हैं।
VETRO पैटर्न एकीकरण के लिए समग्र लचीलापन प्रदान करता है और यह सुनिश्चित करता है कि केवल ESB भर में सुसंगत और मान्य डेटा को रूट किया जाएगा।
Mule ESB क्या है?
Mule ESB एक हल्का और उच्च स्केलेबल जावा-आधारित उद्यम सेवा बस (ESB) है और MuleSoft द्वारा प्रदान किया गया एकीकरण मंच है। Mule ESB डेवलपर को आसानी से और तेज़ी से एप्लिकेशन कनेक्ट करने की अनुमति देता है। अनुप्रयोगों द्वारा उपयोग की जाने वाली विभिन्न तकनीकों के बावजूद, Mule ESB अनुप्रयोगों के आसान एकीकरण को सक्षम करता है, जिससे वे डेटा का आदान-प्रदान कर सकते हैं। Mule ESB के निम्नलिखित दो संस्करण हैं -
- सामुदायिक संस्करण
- एंटरप्राइज़ संस्करण
Mule ESB का एक फायदा यह है कि हम Mule ESB समुदाय से Mule ESB एंटरप्राइज में आसानी से अपग्रेड कर सकते हैं क्योंकि दोनों एडिशन एक कॉमन कोड बेस पर बनाए जाते हैं।
खच्चर ESB की विशेषताएं और क्षमताएं
Mule ESB के पास निम्नलिखित विशेषताएं हैं -
- इसमें सरल ड्रैग-एंड-ड्रॉप ग्राफिकल डिज़ाइन है।
- खच्चर ESB दृश्य डेटा मानचित्रण और परिवर्तन करने में सक्षम है।
- उपयोगकर्ता पूर्व-निर्मित प्रमाणित कनेक्टर्स के 100s की सुविधा प्राप्त कर सकता है।
- केंद्रीकृत निगरानी और प्रशासन।
- यह मजबूत उद्यम सुरक्षा प्रवर्तन क्षमता प्रदान करता है।
- यह एपीआई प्रबंधन की सुविधा प्रदान करता है।
- क्लाउड / ऑन-प्रिमाइसेस कनेक्टिविटी के लिए सुरक्षित डेटा गेटवे है।
- यह सेवा रजिस्ट्री प्रदान करता है, जहां ईएसबी में उजागर सभी सेवाओं को प्रकाशित और पंजीकृत किया जाता है।
- उपयोगकर्ता वेब-आधारित प्रबंधन कंसोल के माध्यम से नियंत्रण कर सकते हैं।
- सर्विस फ्लो एनालाइज़र का उपयोग करके रैपिड डिबगिंग का प्रदर्शन किया जा सकता है।
खच्चर परियोजना के पीछे की प्रेरणाएँ थीं -
प्रोग्रामर के लिए चीजों को सरल बनाने के लिए,
हल्के और मॉड्यूलर समाधान की आवश्यकता है जो कि एक एप्लिकेशन-लेवल मैसेजिंग फ्रेमवर्क से एंटरप्राइज़-वाइड अत्यधिक वितरण योग्य फ्रेमवर्क में स्केल कर सकता है।
Mule ESB को एक इवेंट-संचालित के साथ-साथ प्रोग्रामेटिक फ्रेमवर्क के रूप में तैयार किया गया है। यह ईवेंट-चालित है क्योंकि यह संदेशों के एकीकृत प्रतिनिधित्व के साथ संयुक्त है और प्लग करने योग्य मॉड्यूल के साथ विस्तार योग्य हो सकता है। यह प्रोग्रामेटिक है क्योंकि प्रोग्रामर कुछ अतिरिक्त व्यवहारों जैसे विशिष्ट संदेश प्रसंस्करण या कस्टम डेटा परिवर्तन को आसानी से आरोपित कर सकते हैं।
इतिहास
खच्चर परियोजना का ऐतिहासिक परिप्रेक्ष्य इस प्रकार है -
SourceForge परियोजना
खच्चर परियोजना को अप्रैल 2003 में SourceForge परियोजना के रूप में शुरू किया गया था, और 2 साल बाद इसका पहला संस्करण जारी किया गया था और कोडहॉस में स्थानांतरित कर दिया गया था। यूनिवर्सल मैसेज ऑब्जेक्ट (UMO) API इसकी वास्तुकला के मूल में था। UMO API के पीछे का विचार तर्क को अंतर्निहित ट्रांसपोर्ट से अलग रखते हुए एकीकृत करना था।
संस्करण 1.0
यह अप्रैल 2005 में जारी किया गया था जिसमें कई परिवहन थे। इसके बाद कई अन्य संस्करणों का मुख्य फोकस डिबगिंग और नई सुविधाओं को जोड़ने पर था।
संस्करण 2.0 (स्प्रिंग 2 का दत्तक ग्रहण)
स्प्रिंग 2 को विन्यास और तारों की रूपरेखा के रूप में नियम 2 में अपनाया गया था, लेकिन यह आवश्यक एक्सएमएल कॉन्फ़िगरेशन की स्पष्टता की कमी के कारण एक बड़ा ओवर-हेल साबित हुआ। जब XML स्कीमा-आधारित कॉन्फ़िगरेशन स्प्रिंग 2 में पेश किया गया है, तो यह समस्या हल हो गई थी।
मावेन के साथ भवन
विकास और परिनियोजन के समय, खच्चर के उपयोग को सरल बनाने वाले सबसे बड़े सुधार मावेन का उपयोग था। संस्करण 1.3 से, इसका निर्माण मावेन के साथ किया जाने लगा।
MuleSource
2006 में, MuleSource को "मिशन-महत्वपूर्ण उद्यम अनुप्रयोगों में खच्चर का उपयोग करके तेजी से बढ़ते समुदाय को समर्थन और सक्षम करने में मदद करने के लिए" शामिल हो गया। यह खच्चर परियोजना के लिए महत्वपूर्ण मील का पत्थर साबित हुआ।
खच्चर ESB के प्रतियोगी
Mule ESB के कुछ प्रमुख प्रतियोगी निम्नलिखित हैं -
- डब्लूएसओ २ ईएसबी
- ओरेकल सर्विस बस
- WebSphere Message Broker
- Aurea CX प्लेटफार्म
- फियोरानो ईएसबी
- WebSphere DataPower गेटवे
- कार्यदिवस बिजनेस प्रोसेस फ्रेमवर्क
- टैलेंड एंटरप्राइज सर्विस बस
- JBoss उद्यम सेवा बस
- iWay सेवा प्रबंधक
खच्चर की कोर अवधारणा
जैसा कि चर्चा की गई है, Mule ESB एक हल्का और उच्च स्केलेबल जावा-आधारित उद्यम सेवा बस (ESB) और एकीकरण प्लेटफॉर्म है। अनुप्रयोगों द्वारा उपयोग की जाने वाली विभिन्न तकनीकों के बावजूद, Mule ESB अनुप्रयोगों के आसान एकीकरण को सक्षम करता है, जिससे वे डेटा का आदान-प्रदान कर सकते हैं। इस खंड में, हम इस तरह के एकीकरण को बनाने के लिए म्यूल की मूल अवधारणा के बारे में चर्चा करेंगे।
इसके लिए, हमें इसके आर्किटेक्चर के साथ-साथ बिल्डिंग ब्लॉक्स को भी समझना होगा।
आर्किटेक्चर
Mule ESB की वास्तुकला में तीन परतें हैं जैसे कि परिवहन परत, एकीकरण परत और अनुप्रयोग परत जैसा कि निम्नलिखित चित्र में दिखाया गया है -
आम तौर पर, खच्चर की तैनाती को कॉन्फ़िगर और अनुकूलित करने के लिए तीन प्रकार के कार्य किए जा सकते हैं -
सेवा घटक विकास
इस कार्य में मौजूदा POJO, या स्प्रिंग बीन्स का विकास या पुनः उपयोग शामिल है। POJOs विशेषताओं के साथ एक वर्ग है जो प्राप्त करने और सेट करने के तरीके, क्लाउड कनेक्टर उत्पन्न करता है। दूसरी ओर, स्प्रिंग बीन्स में संदेशों को समृद्ध करने के लिए व्यावसायिक तर्क हैं।
सेवा आर्केस्ट्रा
यह कार्य मूल रूप से सेवा मध्यस्थता प्रदान करता है जिसमें संदेश प्रोसेसर, राउटर, ट्रांसफार्मर और फिल्टर को कॉन्फ़िगर करना शामिल है।
एकीकरण
Mule ESB का सबसे महत्वपूर्ण कार्य विभिन्न अनुप्रयोगों का एकीकरण है, भले ही वे प्रोटोकॉल का उपयोग कर रहे हों। इस उद्देश्य के लिए, खच्चर परिवहन विधियों को प्रदान करता है जो विभिन्न प्रोटोकॉल कनेक्टरों पर संदेश प्राप्त करने और भेजने की अनुमति देता है। खच्चर कई मौजूदा परिवहन विधियों का समर्थन करता है, या हम एक कस्टम परिवहन विधि का उपयोग भी कर सकते हैं।
इमारत ब्लॉकों
खच्चर विन्यास में निम्नलिखित भवन खंड हैं -
वसंत की फलियाँ
स्प्रिंग बीन्स का मुख्य उपयोग सेवा घटक का निर्माण करना है। वसंत सेवा घटक के निर्माण के बाद, हम इसे कॉन्फ़िगरेशन फ़ाइल या मैन्युअल रूप से परिभाषित कर सकते हैं, यदि आपके पास कॉन्फ़िगरेशन फ़ाइल नहीं है।
एजेंटों
यह मूल रूप से Mule Studio से पहले Anypoint Studio में बनाई गई सेवा है। सर्वर शुरू करने के बाद एक एजेंट बनाया जाता है और सर्वर बंद करने के बाद आपको नष्ट कर दिया जाएगा।
योजक
यह एक सॉफ्टवेयर घटक है जो मापदंडों के साथ कॉन्फ़िगर किया गया है जो प्रोटोकॉल के लिए विशिष्ट है। यह मुख्य रूप से एक प्रोटोकॉल के उपयोग को नियंत्रित करने के लिए उपयोग किया जाता है। उदाहरण के लिए, एक JMS कनेक्टर एक के साथ कॉन्फ़िगर किया गया हैConnection और यह कनेक्टर वास्तविक संचार के प्रभारी विभिन्न संस्थाओं के बीच साझा किया जाएगा।
वैश्विक विन्यास
जैसा कि नाम से ही स्पष्ट है, यह बिल्डिंग ब्लॉक वैश्विक गुणों और सेटिंग्स को सेट करने के लिए उपयोग किया जाता है।
ग्लोबल एंडपॉइंट्स
इसका उपयोग ग्लोबल एलिमेंट्स टैब में किया जा सकता है जिसे एक प्रवाह में कई बार उपयोग किया जा सकता है -
ग्लोबल मैसेज प्रोसेसर
जैसा कि नाम का अर्थ है, यह एक संदेश या संदेश प्रवाह को देखता या संशोधित करता है। ट्रांसफॉर्मर और फिल्टर ग्लोबल मैसेज प्रोसेसर के उदाहरण हैं।
Transformers- एक ट्रांसफार्मर का मुख्य काम डेटा को एक प्रारूप से दूसरे में बदलना है। इसे विश्व स्तर पर परिभाषित किया जा सकता है और इसका उपयोग कई प्रवाह में किया जा सकता है।
Filters- यह फिल्टर है जो तय करेगा कि किस खच्चर संदेश को संसाधित किया जाना चाहिए। फ़िल्टर मूल रूप से उन शर्तों को निर्दिष्ट करता है जो किसी संदेश को संसाधित करने और सेवा में रूट करने के लिए मिलना चाहिए।
मॉडल
एजेंटों के विपरीत, यह सेवाओं का एक तार्किक समूह है जो स्टूडियो में बनाया गया है। हमारे पास एक विशिष्ट मॉडल के अंदर सभी सेवाओं को शुरू करने और रोकने की स्वतंत्रता है।
Services- सेवाएं वह हैं जो हमारे व्यापारिक तर्क या घटकों को लपेटती हैं। यह राउटर, एंडपॉइंट, ट्रांसफार्मर और फिल्टर को उस सेवा के लिए विशेष रूप से कॉन्फ़िगर करता है।
Endpoints- इसे एक ऐसी वस्तु के रूप में परिभाषित किया जा सकता है जिस पर सेवाएं इनबाउंड (प्राप्त) और आउटबाउंड (संदेश) भेजेंगी। सेवाएं समापन बिंदुओं के माध्यम से जुड़ी हुई हैं।
बहे
संदेश प्रोसेसर का उपयोग किसी स्रोत और लक्ष्य के बीच संदेश प्रवाह को परिभाषित करने के लिए प्रवाह का उपयोग करता है।
खच्चर संदेश संरचना
खच्चर संदेश ऑब्जेक्ट के तहत पूरी तरह से लिपटे एक खच्चर संदेश, वह डेटा है जो खच्चर के प्रवाह के माध्यम से अनुप्रयोगों से गुजरता है। Mule का संदेश निम्नलिखित आरेख में दिखाया गया है -
जैसा कि ऊपर चित्र में देखा गया है, खच्चर संदेश में दो मुख्य भाग होते हैं -
हैडर
यह संदेश के मेटाडेटा के अलावा और कुछ नहीं है, जो निम्नलिखित दो गुणों द्वारा प्रस्तुत किया गया है -
Inbound Properties- ये वे गुण हैं जो संदेश स्रोत द्वारा स्वचालित रूप से सेट किए जाते हैं। उन्हें उपयोगकर्ता द्वारा हेरफेर या सेट नहीं किया जा सकता है। प्रकृति में, आवक गुण अपरिवर्तनीय हैं।
Outbound Properties- ये ऐसे गुण हैं जिनमें मेटाडेटा इनबाउंड संपत्ति की तरह है और प्रवाह के दौरान सेट कर सकते हैं। वे स्वचालित रूप से एक उपयोगकर्ता द्वारा खच्चर या मैन्युअल रूप से सेट किए जा सकते हैं। प्रकृति में, आउटबाउंड गुण परस्पर भिन्न होते हैं।
जब संदेश एक ट्रांसपोर्ट के माध्यम से एक अलग प्रवाह के इनबाउंड एंडपॉइंट के आउटबाउंड समापन बिंदु से गुजरता है, तो आउटबाउंड गुण इनबाउंड गुण बन जाते हैं।
जब एक कनेक्टर के बजाय प्रवाह-प्रवाह के माध्यम से एक नए प्रवाह को संदेश भेजा जाता है, तो आउटबाउंड गुण आउटबाउंड गुण रहते हैं।
पेलोड
संदेश ऑब्जेक्ट द्वारा किए गए वास्तविक व्यावसायिक संदेश को पेलोड कहा जाता है।
चर
यह एक संदेश के बारे में उपयोगकर्ता द्वारा परिभाषित मेटाडेटा के रूप में परिभाषित किया जा सकता है। मूल रूप से, चर उस एप्लिकेशन द्वारा उपयोग किए गए संदेश के बारे में जानकारी के अस्थायी टुकड़े होते हैं जो इसे संसाधित कर रहे हैं। यह अपने गंतव्य के संदेशों के साथ पारित होने के लिए नहीं है। वे नीचे दिए गए अनुसार तीन प्रकार के हैं -
Flow variables - ये चर केवल उस प्रवाह पर लागू होते हैं जिसमें वे मौजूद हैं।
Session variables - ये चर एक ही अनुप्रयोग के भीतर सभी प्रवाह पर लागू होते हैं।
Record variables - ये चर एक बैच के हिस्से के रूप में संसाधित अभिलेखों पर ही लागू होते हैं।
अनुलग्नक और अतिरिक्त पेलोड
संदेश पेलोड के बारे में ये कुछ अतिरिक्त मेटाडेटा हैं जो जरूरी नहीं कि हर बार संदेश वस्तु में दिखाई दें।
पिछले अध्यायों में, हमने Mule ESB की मूल बातें सीख ली हैं। इस अध्याय में, आइए जानें कि इसे कैसे संस्थापित और कॉन्फ़िगर किया जाए।
आवश्यक शर्तें
हमें अपने कंप्यूटर पर खच्चर को स्थापित करने से पहले निम्न शर्त को पूरा करना होगा -
जावा डेवलपमेंट किट (JDK)
MULE को स्थापित करने से पहले, सत्यापित करें कि आपने अपने सिस्टम पर Java का समर्थन संस्करण बनाया है। JDK 1.8.0 को आपके सिस्टम पर Mule को सफलतापूर्वक स्थापित करने के लिए अनुशंसित किया गया है।
ऑपरेटिंग सिस्टम
निम्नलिखित ऑपरेटिंग सिस्टम खच्चर द्वारा समर्थित हैं -
- MacOS 10.11.x
- HP-UX 11iV3
- AIX 7.2
- विंडोज 2016 सर्वर
- विंडोज 2012 R2 सर्वर
- विंडोज 10
- विंडोज 8.1
- सोलारिस 11.3
- आरएचईएल 7
- उबंटू सर्वर 18.04
- लिनक्स कर्नेल 3.13+
डेटाबेस
अनुप्रयोग सर्वर या डेटाबेस की आवश्यकता नहीं है क्योंकि खच्चर रनटाइम एक स्टैंडअलोन सर्वर के रूप में चलता है। लेकिन अगर हमें किसी डेटा स्टोर तक पहुंचने या किसी एप्लिकेशन सर्वर का उपयोग करने की आवश्यकता है, तो समर्थित एप्लिकेशन सर्वर या डेटाबेस का उपयोग किया जा सकता है -
- ओरेकल 11 जी
- ओरेकल 12 सी
- MySQL 5.5+
- आईबीएम DB2 10
- PostgreSQL 9
- डर्बी १०
- Microsoft SQL Server 2014
सिस्टम आवश्यकताएं
अपने सिस्टम पर खच्चर को स्थापित करने से पहले, इसे निम्नलिखित सिस्टम आवश्यकताओं को पूरा करना होगा -
- वर्चुअलाइज्ड वातावरण में कम से कम 2 गीगाहर्ट्ज सीपीयू या 1 वर्चुअल सीपीयू
- न्यूनतम 1 जीबी रैम
- न्यूनतम 4 जीबी स्टोरेज
डाउनलोड करें खच्चर
खच्चर 4 बाइनरी फ़ाइल डाउनलोड करने के लिए, लिंक पर क्लिक करें https://www.mulesoft.com/lp/dl/mule-esb-enterprise और यह आपको MuleSoft के आधिकारिक वेब पेज पर ले जाएगा -
आवश्यक विवरण प्रदान करके, आप Mule 4 बाइनरी फ़ाइल को ज़िप प्रारूप में प्राप्त कर सकते हैं।
स्थापित करें और भागो खच्चर
अब Mule 4 बाइनरी फ़ाइल को डाउनलोड करने के बाद, इसे अनज़िप करें और पर्यावरण वैरिएबल सेट करें जिसे कहा जाता है MULE_HOME निकाले गए फ़ोल्डर के अंदर खच्चर निर्देशिका के लिए।
उदाहरण के लिए, विंडोज और लिनक्स / यूनिक्स वातावरण पर पर्यावरण चर, डाउनलोड निर्देशिका में संस्करण 4.1.5 के लिए सेट किया जा सकता है -
विंडोज वातावरण
$ env:MULE_HOME=C:\Downloads\mule-enterprise-standalone-4.1.5\
यूनिक्स / लिनक्स वातावरण
$ export MULE_HOME=~/Downloads/mule-enterprise-standalone-4.1.5/
अब, परीक्षण के लिए कि क्या खच्चर आपके सिस्टम में बिना किसी त्रुटि के चल रहा है, निम्नलिखित कमांड का उपयोग करें -
विंडोज वातावरण
$ $MULE_HOME\bin\mule.bat
यूनिक्स / लिनक्स वातावरण
$ $MULE_HOME/bin/mule
उपरोक्त कमांड्स Mule को अग्रभूमि मोड में चलाएंगे। यदि खच्चर चल रहा है, तो हम टर्मिनल पर कोई अन्य आदेश जारी नहीं कर सकते। दबानाctrl-c टर्मिनल में कमांड, खच्चर को रोक देगा।
खच्चर सेवा शुरू करें
हम खच्चर को Windows सेवा के रूप में और लिनक्स / यूनिक्स डेमन के रूप में भी शुरू कर सकते हैं।
विंडोज सेवा के रूप में खच्चर
खच्चर को विंडोज सेवा के रूप में चलाने के लिए, हमें निम्न चरणों का पालन करने की आवश्यकता है -
Step 1 - सबसे पहले, निम्नलिखित कमांड की सहायता से इसे स्थापित करें -
$ $MULE_HOME\bin\mule.bat install
Step 2 - एक बार स्थापित होने के बाद, हम निम्नलिखित कमांड की मदद से खच्चर को Windows सेवा के रूप में चला सकते हैं:
$ $MULE_HOME\bin\mule.bat start
लिनक्स / यूनिक्स डेमॉन के रूप में खच्चर
Mule को Linux / Unix Daemon के रूप में चलाने के लिए, हमें निम्न चरणों का पालन करने की आवश्यकता है -
Step 1 - इसे निम्न कमांड की सहायता से स्थापित करें -
$ $MULE_HOME/bin/mule install
Step 2 - एक बार स्थापित होने के बाद, हम निम्नलिखित आदेश की मदद से खच्चर को विंडोज सेवा के रूप में चला सकते हैं -
$ $MULE_HOME/bin/mule start
Example
निम्नलिखित उदाहरण खच्चर को यूनिक्स डेमन के रूप में शुरू करता है -
$ $MULE_HOME/bin/mule start
MULE_HOME is set to ~/Downloads/mule-enterprise-standalone-4.1.5
MULE_BASE is set to ~/Downloads/mule-enterprise-standalone-4.1.5
Starting Mule Enterprise Edition...
Waiting for Mule Enterprise Edition.................
running: PID:87329
खच्चर एप्लिकेशन तैनात करें
हम निम्नलिखित चरणों की मदद से अपने खच्चर ऐप्स को तैनात कर सकते हैं -
Step 1 - सबसे पहले, खच्चर शुरू करें।
Step 2 - एक बार खच्चर शुरू होने के बाद, हम अपने JAR पैकेज फ़ाइलों को स्थानांतरित करके अपने खच्चर अनुप्रयोगों को तैनात कर सकते हैं apps में निर्देशिका $MULE_HOME।
खच्चर सेवा बंद करो
हम प्रयोग कर सकते हैं stopखच्चर को रोकने की आज्ञा। उदाहरण के लिए, निम्नलिखित उदाहरण मूले को यूनिक्स डेमन के रूप में शुरू करता है -
$ $MULE_HOME/bin/mule stop
MULE_HOME is set to /Applications/mule-enterprise-standalone-4.1.5
MULE_BASE is set to /Applications/mule-enterprise-standalone-4.1.5
Stopping Mule Enterprise Edition...
Stopped Mule Enterprise Edition.
हम भी उपयोग कर सकते हैं removeहमारी प्रणाली से खच्चर सेवा या डेमॉन को हटाने की आज्ञा। निम्नलिखित उदाहरण खच्चर को यूनिक्स डेमन के रूप में हटाता है -
$ $MULE_HOME/bin/mule remove
MULE_HOME is set to /Applications/mule-enterprise-standalone-4.1.5
MULE_BASE is set to /Applications/mule-enterprise-standalone-4.1.5
Detected Mac OSX:
Mule Enterprise Edition is not running.
Removing Mule Enterprise Edition daemon...
MuleSoft's Anypoint Studio एक उपयोगकर्ता के अनुकूल है IDE (integration development environment)खच्चर अनुप्रयोगों के डिजाइन और परीक्षण के लिए उपयोग किया जाता है। यह एक ग्रहण-आधारित आईडीई है। हम आसानी से खच्चर पैलेट से कनेक्टर्स को खींच सकते हैं। दूसरे शब्दों में, Anypoint Studio प्रवाह, आदि के विकास के लिए एक ग्रहण आधारित IDE है।
आवश्यक शर्तें
हमें सभी OS, यानी, Windows, Mac और Linux / Unix पर Mule स्थापित करने से पहले किसी और चीज का पालन करने की आवश्यकता है।
Java Development Kit (JDK)- खच्चर को स्थापित करने से पहले, सत्यापित करें कि आपने अपने सिस्टम पर जावा का संस्करण समर्थित है। JDK 1.8.0 आपके सिस्टम पर Anypoint को सफलतापूर्वक स्थापित करने के लिए अनुशंसित है।
डाउनलोड और इंस्टॉल करना Anypoint Studio
अलग-अलग ऑपरेटिंग सिस्टम पर Anypoint Studio को डाउनलोड और इंस्टॉल करने की प्रक्रिया अलग-अलग हो सकती है। इसके बाद, विभिन्न ऑपरेटिंग सिस्टमों पर Anypoint Studio को डाउनलोड करने और स्थापित करने के लिए निम्नलिखित चरणों का पालन किया जाना है -
विंडोज पर
Windows पर Anypoint Studio को डाउनलोड और इंस्टॉल करने के लिए, हमें नीचे दिए गए चरणों का पालन करना होगा -
Step 1 - सबसे पहले लिंक पर क्लिक करें https://www.mulesoft.com/lp/dl/studio और स्टूडियो को डाउनलोड करने के लिए टॉप-डाउन सूची से विंडोज ऑपरेटिंग सिस्टम चुनें।
Step 2 - अब, इसे में निकालें ‘C:\’ मूल फ़ोल्डर।
Step 3 - निकाले गए Anypoint Studio को खोलें।
Step 4- डिफ़ॉल्ट कार्यक्षेत्र स्वीकार करने के लिए, ठीक पर क्लिक करें। पहली बार लोड होने पर आपको एक स्वागत योग्य संदेश मिलेगा।
Step 5 - अब, Anypoint Studio का उपयोग करने के लिए Get Started बटन पर क्लिक करें।
ओएस एक्स पर
OS X पर Anypoint Studio को डाउनलोड और इंस्टॉल करने के लिए, हमें नीचे दिए गए चरणों का पालन करना होगा -
Step 1 - सबसे पहले लिंक पर क्लिक करें https://www.mulesoft.com/lp/dl/studio और स्टूडियो डाउनलोड करें।
Step 2- अब, इसे निकालें। यदि आप ओएस संस्करण सिएरा का उपयोग कर रहे हैं तो इस स्थिति में, निकाले गए ऐप को स्थानांतरित करना सुनिश्चित करें/Applications folder इसे लॉन्च करने से पहले।
Step 3 - निकाले गए Anypoint Studio को खोलें।
Step 4- डिफ़ॉल्ट कार्यक्षेत्र स्वीकार करने के लिए, ठीक पर क्लिक करें। पहली बार लोड होने पर आपको एक स्वागत योग्य संदेश मिलेगा।
Step 5 - अब, पर क्लिक करें Get Started Anypoint स्टूडियो का उपयोग करने के लिए बटन।
यदि आप अपने कार्यक्षेत्र में कस्टम पथ का उपयोग करने जा रहे हैं, तो कृपया ध्यान दें कि Anypoint Studio लिनक्स / यूनिक्स सिस्टम में उपयोग किए जाने वाले ~ टिल्ड का विस्तार नहीं करता है। इसलिए, कार्यक्षेत्र को परिभाषित करते समय निरपेक्ष पथ का उपयोग करने की सिफारिश की जाती है।
लिनक्स पर
लिनक्स पर Anypoint Studio को डाउनलोड और इंस्टॉल करने के लिए, हमें नीचे दिए गए चरणों का पालन करना होगा -
Step 1 - सबसे पहले लिंक पर क्लिक करें https://www.mulesoft.com/lp/dl/studio और स्टूडियो को डाउनलोड करने के लिए टॉप-डाउन सूची से लिनक्स ऑपरेटिंग सिस्टम चुनें।
Step 2 - अब, इसे निकालें।
Step 3 - इसके बाद निकाले गए Anypoint Studio को खोलें।
Step 4- डिफ़ॉल्ट कार्यक्षेत्र स्वीकार करने के लिए, ठीक पर क्लिक करें। पहली बार लोड होने पर आपको एक स्वागत योग्य संदेश मिलेगा।
Step 5 - अब, Anypoint Studio का उपयोग करने के लिए Get Started बटन पर क्लिक करें।
यदि आप अपने कार्यक्षेत्र में कस्टम पथ का उपयोग करने जा रहे हैं, तो कृपया ध्यान दें कि Anypoint Studio लिनक्स / यूनिक्स सिस्टम में उपयोग किए जाने वाले ~ टिल्ड का विस्तार नहीं करता है। इसलिए, कार्यक्षेत्र को परिभाषित करते समय निरपेक्ष पथ का उपयोग करने की सिफारिश की जाती है।
लिनक्स में संपूर्ण स्टूडियो थीम्स का उपयोग करने के लिए GTK संस्करण 2 को स्थापित करने की भी सिफारिश की गई है।
Anypoint स्टूडियो की विशेषताएं
खच्चर के अनुप्रयोगों का निर्माण करते समय उत्पादकता बढ़ाने वाले एनीपॉइंट स्टूडियो की कुछ विशेषताएं निम्नलिखित हैं -
यह एक स्थानीय रनटाइम के अंदर खच्चर एप्लिकेशन का एक त्वरित रन प्रदान करता है।
Anypoint स्टूडियो हमें एपीआई परिभाषा फ़ाइलों और खच्चर डोमेन को कॉन्फ़िगर करने के लिए दृश्य संपादक देता है।
इसमें उत्पादकता को बढ़ाने वाली इकाई परीक्षण रूपरेखा है।
Anypoint स्टूडियो हमें CloudHub परिनियोजित करने के लिए अंतर्निहित समर्थन प्रदान करता है।
इसमें अन्य Anypoint प्लेटफ़ॉर्म संगठन से टेम्पलेट्स, उदाहरणों, परिभाषाओं और अन्य संसाधनों को आयात करने के लिए एक्सचेंज के साथ एकीकृत करने की सुविधा है।
Anypoint Studio संपादकों को हमारे एप्लिकेशन, API, गुण और कॉन्फ़िगरेशन फ़ाइलों को डिज़ाइन करने में मदद करते हैं। डिजाइनिंग के साथ-साथ, यह हमें उन्हें संपादित करने में भी मदद करता है। हमारे पास इस उद्देश्य के लिए खच्चर कॉन्फ़िगरेशन फ़ाइल संपादक है। इस संपादक को खोलने के लिए, आवेदन XML फ़ाइल पर डबल-क्लिक करें/src/main/mule।
हमारे आवेदन के साथ काम करने के लिए, हमारे पास Mule कॉन्फ़िगरेशन फ़ाइल संपादक के तहत निम्नलिखित तीन टैब हैं।
संदेश प्रवाह टैब
यह टैब कार्य प्रवाह का एक दृश्य प्रतिनिधित्व देता है। इसमें मूल रूप से एक कैनवास होता है जो हमें अपने प्रवाह को नेत्रहीन रूप से जांचने में मदद करता है। यदि आप Mule Palette से Event Processors को कैनवास में जोड़ना चाहते हैं, तो बस खींचें और छोड़ें और यह कैनवास में प्रतिबिंबित होगा।
ईवेंट प्रोसेसर पर क्लिक करके, आप चयनित प्रोसेसर के गुणों के साथ खच्चर गुण दृश्य प्राप्त कर सकते हैं। हम उन्हें संपादित भी कर सकते हैं।
ग्लोबल एलिमेंट्स टैब
इस टैब में मॉड्यूल के लिए वैश्विक खच्चर विन्यास तत्व शामिल हैं। इस टैब के तहत हम कॉन्फ़िगरेशन फ़ाइलों को बना सकते हैं, संपादित कर सकते हैं या हटा सकते हैं।
कॉन्फ़िगरेशन XML टैब
जैसा कि नाम से ही स्पष्ट है, इसमें एक्सएमएल है जो आपके खच्चर को परिभाषित करता है। आपके द्वारा यहां किए जाने वाले सभी परिवर्तन कैनवास में और साथ ही संदेश प्रवाह टैब के अंतर्गत ईवेंट प्रोसेसर के गुणों को भी प्रतिबिंबित करेंगे।
विचारों
सक्रिय संपादक के लिए, एनीपॉइंट स्टूडियो हमें अपनी परियोजना मेटाडाटा के चित्रमय प्रतिनिधित्व, विचारों की मदद से गुण प्रदान करता है। एक उपयोगकर्ता स्थानांतरित कर सकता है, साथ ही साथ खच्चर परियोजना में विचार जोड़ सकता है। Anypoint स्टूडियो में कुछ डिफ़ॉल्ट दृश्य निम्नलिखित हैं -
पैकेज एक्सप्लोरर
पैकेज एक्सप्लोरर दृश्य का मुख्य कार्य परियोजना फ़ोल्डर और फाइलों को प्रदर्शित करना है, जिसमें एक खच्चर परियोजना शामिल है। हम इसके बगल में तीर पर क्लिक करके खच्चर परियोजना फ़ोल्डर का विस्तार या अनुबंध कर सकते हैं। एक फ़ोल्डर या फ़ाइल को डबल क्लिक करके खोला जा सकता है। एक नजर इसके स्क्रीनशॉट पर -
खच्चर पैलेट
खच्चर पैलेट दृश्य मॉड्यूल और उनके संबंधित संचालन के साथ घटना प्रोसेसर जैसे कि स्कोप, फिल्टर और फ्लो कंट्रोल रूटर्स को दिखाता है। मुले पैलेट दृश्य के मुख्य कार्य इस प्रकार हैं -
- यह दृश्य हमें अपनी परियोजना में मॉड्यूल और कनेक्टर्स का प्रबंधन करने में मदद करता है।
- हम Exchange से नए तत्व भी जोड़ सकते हैं।
एक नजर इसके स्क्रीनशॉट पर -
खच्चर के गुण
जैसा कि नाम से ही स्पष्ट है, यह हमें वर्तमान में हमारे कैनवास में चयनित मॉड्यूल के गुणों को संपादित करने की अनुमति देता है। खच्चर गुण दृश्य में निम्नलिखित शामिल हैं -
DataSense एक्सप्लोरर जो हमारे पेलोड के डेटा संरचना के बारे में वास्तविक समय की जानकारी प्रदान करता है।
इनबाउंड और आउटबाउंड गुण, यदि उपलब्ध या चर।
नीचे स्क्रीनशॉट है -
कंसोल
जब भी हम Mule एप्लिकेशन को बनाते या चलाते हैं, तो एम्बेडेड Mule सर्वर स्टूडियो द्वारा रिपोर्ट की गई घटनाओं और समस्याओं की सूची प्रदर्शित करता है। कंसोल दृश्य में उस एम्बेडेड खच्चर सर्वर का कंसोल होता है। एक नजर इसके स्क्रीनशॉट पर -
समस्याएँ देखें
हम अपने खच्चर परियोजना पर काम करते समय कई मुद्दों का सामना कर सकते हैं। उन सभी समस्याओं को समस्या दृश्य में प्रदर्शित किया जाता है। नीचे स्क्रीनशॉट है
दृष्टिकोण
Anypoint Studio में, यह एक निर्दिष्ट व्यवस्था में विचारों और संपादकों का एक संग्रह है। Anypoint Studio में दो तरह के दृष्टिकोण हैं -
Mule Design Perspective - यह डिफ़ॉल्ट परिप्रेक्ष्य है जो हमें स्टूडियो में मिलता है।
Mule Debug Perspective - एनीपॉइंट स्टूडियो द्वारा आपूर्ति किया गया एक और दृष्टिकोण है, मुल डिबग पर्सपेक्टिव।
दूसरी ओर, हम अपना स्वयं का दृष्टिकोण भी बना सकते हैं और किसी भी डिफ़ॉल्ट विचार को जोड़ या हटा सकते हैं।
इस अध्याय में हम MuleSoft's Anypoint Studio में अपना पहला खच्चर एप्लिकेशन बनाने जा रहे हैं। इसे बनाने के लिए, पहले हमें Anypoint Studio लॉन्च करने की आवश्यकता है।
लॉन्चिंग एनीपॉइंट स्टूडियो
इसे लॉन्च करने के लिए Anypoint Studio पर क्लिक करें। यदि आप इसे पहली बार लॉन्च कर रहे हैं, तो आपको निम्न विंडो दिखाई देगी -
Anypoint Studio का उपयोगकर्ता इंटरफ़ेस
एक बार जब आप कार्यस्थान पर जाएं बटन पर क्लिक करते हैं, तो यह आपको निम्नानुसार Anypoint Studio के उपयोगकर्ता इंटरफ़ेस तक ले जाएगा -
खच्चर आवेदन बनाने के लिए कदम
अपना खच्चर एप्लिकेशन बनाने के लिए, नीचे दिए गए चरणों का पालन करें -
नया प्रोजेक्ट बनाना
खच्चर एप्लिकेशन बनाने के लिए पहला कदम एक नया प्रोजेक्ट बनाना है। यह मार्ग का अनुसरण करके किया जा सकता हैFILE → NEW → Mule Project जैसा कि नीचे दिखाया गया है -
परियोजना का नामकरण
नए Mule Project पर क्लिक करने के बाद, जैसा कि ऊपर बताया गया है, यह प्रोजेक्ट का नाम और अन्य विशिष्टताओं के लिए पूछते हुए एक नई विंडो खोलेगा। प्रोजेक्ट का नाम दीजिए, 'TestAPP1'और फिर फिनिश बटन पर क्लिक करें।
एक बार जब आप फिनिश बटन पर क्लिक करते हैं, तो यह आपके MuleProject के लिए निर्मित कार्यक्षेत्र को खोल देगा ‘TestAPP1’। आप सब देख सकते हैंEditors तथा Views पिछले अध्याय में वर्णित है।
कनेक्टर को कॉन्फ़िगर करना
यहां, हम HTTP श्रोता के लिए एक सरल नियम आवेदन बनाने जा रहे हैं। इसके लिए, हमें Mule Palette से HTTP श्रोता कनेक्टर को खींचने और इसे नीचे दिए गए कार्यक्षेत्र में छोड़ने की आवश्यकता है -
अब, हमें इसे कॉन्फ़िगर करने की आवश्यकता है। जैसा कि ऊपर दिखाया गया है, बेसिक सेटिंग्स के तहत कनेक्टर कॉन्फ़िगरेशन के बाद हरे रंग पर क्लिक करें।
ठीक क्लिक करने पर, यह आपको HTTP श्रोता संपत्ति पृष्ठ पर वापस ले जाएगा। अब हमें जनरल टैब के तहत पथ प्रदान करने की आवश्यकता है। इस विशेष उदाहरण में, हमने प्रदान किया है/FirstAPP पथ के नाम के रूप में।
सेट पेलोड कनेक्टर को कॉन्फ़िगर करना
अब, हमें एक सेट पेलोड कनेक्टर लेने की जरूरत है। हमें निम्न के रूप में सेटिंग्स टैब के तहत इसके मूल्य देने की आवश्यकता है -
This is my first Mule Application, इस उदाहरण में प्रदान किया गया नाम है।
चल रहा है खच्चर आवेदन
अब, इसे सहेजें और क्लिक करें Run as Mule Application जैसा कि नीचे दिखाया गया है -
हम इसे कंसोल के तहत चेक कर सकते हैं जो एप्लिकेशन को निम्नानुसार दर्शाती है -
यह दर्शाता है कि आपने अपना पहला खच्चर एप्लिकेशन सफलतापूर्वक बनाया है।
खच्चर आवेदन का सत्यापन
अब, हमें यह परीक्षण करने की आवश्यकता है कि हमारा ऐप चल रहा है या नहीं। Go to POSTMAN, Chrome एप्लिकेशन और Url दर्ज करें: http:/localhost:8081। यह हमारे द्वारा प्रदान किए गए संदेश को दिखाता है, जैसा कि नीचे दिखाया गया है।
DataWeave मूल रूप से एक MuleSoft अभिव्यक्ति भाषा है। यह मुख्य रूप से एक खच्चर एप्लिकेशन के माध्यम से प्राप्त डेटा तक पहुंचने और बदलने के लिए उपयोग किया जाता है। खच्चर रनटाइम हमारे खच्चर आवेदन में स्क्रिप्ट और भावों को चलाने के लिए जिम्मेदार है, DataWeave जोर से खच्चर रनटाइम के साथ एकीकृत है।
डाटावेव भाषा की विशेषताएं
DataWeave भाषा की कुछ महत्वपूर्ण विशेषताएं निम्नलिखित हैं -
डेटा को एक प्रारूप से दूसरे में बहुत आसानी से रूपांतरित किया जा सकता है। उदाहरण के लिए, हम एप्लिकेशन / json को एप्लिकेशन / xml में बदल सकते हैं। इनपुट पेलोड इस प्रकार है -
{
"title": "MuleSoft",
"author": " tutorialspoint.com ",
"year": 2019
}
निम्नलिखित परिवर्तन के लिए DataWeave में कोड है -
%dw 2.0
output application/xml
---
{
order: {
'type': 'Tutorial',
'title': payload.title,
'author': upper(payload.author),
'year': payload.year
}
}
इसके बाद द output पेलोड इस प्रकार है -
<?xml version = '1.0' encoding = 'UTF-8'?>
<order>
<type>Tutorial</type>
<title>MuleSoft</title>
<author>tutorialspoint.com</author>
<year>2019</year>
</order>
ट्रांसफ़ॉर्म घटक का उपयोग स्क्रिप्ट बनाने के लिए किया जा सकता है जो सरल और जटिल डेटा ट्रांसफ़ॉर्मेशन दोनों करता है।
हम Mule इवेंट के उन हिस्सों पर मुख्य DataWeave फ़ंक्शंस तक पहुँच और उपयोग कर सकते हैं, जिन्हें हमें Mule मैसेज प्रोसेसर की सबसे अधिक आवश्यकता होती है, जो DataWeave अभिव्यक्तियों का समर्थन करते हैं।
आवश्यक शर्तें
हमें अपने कंप्यूटर पर डेटाविवे स्क्रिप्ट का उपयोग करने से पहले निम्नलिखित आवश्यक शर्तें पूरी करनी होंगी -
Dataweave स्क्रिप्ट का उपयोग करने के लिए Anypoint Studio 7 की आवश्यकता है।
Anypoint Studio को स्थापित करने के बाद, हमें DataWeave स्क्रिप्ट का उपयोग करने के लिए एक ट्रांसफॉर्म संदेश घटक के साथ एक परियोजना स्थापित करने की आवश्यकता है।
उदाहरण के साथ DataWeave स्क्रिप्ट का उपयोग करने के लिए चरण
DataWeave विभाजन का उपयोग करने के लिए, हमें नीचे दिए गए चरणों का पालन करना होगा -
Step 1
सबसे पहले, हमें एक नई परियोजना स्थापित करने की आवश्यकता है, जैसा कि हमने पिछले अध्याय में उपयोग करके किया था File → New → Mule Project।
Step 2
अगला, हमें परियोजना का नाम प्रदान करने की आवश्यकता है। इस उदाहरण के लिए, हम नाम दे रहे हैं,Mule_test_script।
Step 3
अब, हमें इसे खींचने की आवश्यकता है Transform Message component से Mule Palette tab जांच canvas। इसे नीचे दिखाया गया है -
Step 4
इसके बाद, में Transform Message componentटैब, पूर्वावलोकन फलक खोलने के लिए पूर्वावलोकन पर क्लिक करें। हम पूर्वावलोकन के बगल में खाली आयत पर क्लिक करके स्रोत कोड क्षेत्र का विस्तार कर सकते हैं।
Step 5
अब, हम DataWeave भाषा के साथ स्क्रिप्टिंग शुरू कर सकते हैं।
उदाहरण
निम्नलिखित दो तारों को एक में समाहित करने का सरल उदाहरण है -
उपरोक्त DataWeave स्क्रिप्ट में एक कुंजी-मूल्य जोड़ी है ({ myString: ("hello" ++ "World") }) जो दो तारों को एक में समेट देगा।
स्क्रिप्टिंग मॉड्यूल उपयोगकर्ताओं को खच्चर में स्क्रिप्टिंग भाषा का उपयोग करने की सुविधा प्रदान करते हैं। सरल शब्दों में, स्क्रिप्टिंग मॉड्यूल स्क्रिप्टिंग भाषा में लिखे गए कस्टम तर्क का आदान-प्रदान कर सकता है। लिपियों का उपयोग कार्यान्वयन या ट्रांसफार्मर के रूप में किया जा सकता है। उन्हें संदेश मूल्यांकन को नियंत्रित करने के लिए, अभिव्यक्ति मूल्यांकन के लिए उपयोग किया जा सकता है।
खच्चर की निम्नलिखित समर्थित स्क्रिप्टिंग भाषाएँ हैं -
- Groovy
- Python
- JavaScript
- Ruby
स्क्रिप्टिंग मॉड्यूल कैसे स्थापित करें?
दरअसल, Anypoint Studio स्क्रिप्टिंग मॉड्यूल के साथ आता है। यदि आपको खच्चर पैलेट में मॉड्यूल नहीं मिलता है, तो इसका उपयोग करके जोड़ा जा सकता है+Add Module। जोड़ने के बाद, हम अपने खच्चर आवेदन में स्क्रिप्टिंग मॉड्यूल संचालन का उपयोग कर सकते हैं।
उदाहरण को लागू करना
जैसा कि चर्चा की गई है, हमें कार्यक्षेत्र बनाने के लिए मॉड्यूल को कैनवास में खींचने और छोड़ने की जरूरत है और हमारे आवेदन में इसका उपयोग करें। निम्नलिखित इसका एक उदाहरण है -
हम पहले से ही जानते हैं कि HTTP श्रोता घटक को कैसे कॉन्फ़िगर किया जाए; इसलिए हम स्क्रिप्टिंग मॉड्यूल को कॉन्फ़िगर करने के बारे में चर्चा करने जा रहे हैं। हमें स्क्रिप्टिंग मॉड्यूल को कॉन्फ़िगर करने के लिए नीचे लिखे चरणों का पालन करना होगा -
Step 1
खच्चर पैलेट से स्क्रिप्टिंग मॉड्यूल के लिए खोजें और खींचें EXECUTE आपके प्रवाह में स्क्रिप्टिंग मॉड्यूल का संचालन जैसा कि ऊपर दिखाया गया है।
Step 2
अब, उसी पर डबल क्लिक करके एक्सक्यूट कॉन्फ़िगरेशन टैब खोलें।
Step 3
के नीचे General टैब, हमें कोड प्रदान करने की आवश्यकता है Code text window जैसा कि नीचे दिखाया गया है -
Step 4
अंत में, हमें चुनने की जरूरत है Engineनिष्पादित घटक से। इंजनों की सूची इस प्रकार है -
- Groovy
- Nashorn(javaScript)
- jython(Python)
- jRuby(Ruby)
कॉन्फ़िगरेशन एक्सएमएल संपादक में उपरोक्त निष्पादन उदाहरण का XML निम्नानुसार है -
<scripting:execute engine="jython" doc:name = "Script">
<scripting:code>
def factorial(n):
if n == 0: return 1
return n * factorial(n-1)
result = factorial(10)
</scripting:code>
</scripting:execute>
संदेश स्रोत
Mule 4 में Mule 3 संदेश की तुलना में एक सरलीकृत मॉडल है, जिससे सूचनाओं को अधिलेखित किए बिना कनेक्टर्स के अनुरूप तरीके से डेटा के साथ काम करना आसान हो जाता है। नियम 4 संदेश मॉडल में, प्रत्येक खच्चर घटना में दो चीजें होती हैं:a message and variables associated with it।
एक खच्चर संदेश में पेलोड और उसकी विशेषताएँ होती हैं, जहाँ मुख्य रूप से फ़ाइल आकार जैसे मेटाडेटा का गुण होता है।
और एक चर उपयोगकर्ता की मनमानी जानकारी रखता है जैसे कि ऑपरेशन परिणाम, सहायक मूल्य आदि।
भीतर का
Mule 3 में इनबाउंड गुण अब Mule 4 में विशेषता बन जाते हैं। जैसा कि हम जानते हैं कि इनबाउंड गुण संदेश स्रोत के माध्यम से प्राप्त पेलोड के बारे में अतिरिक्त जानकारी संग्रहीत करते हैं, लेकिन यह अब, Mule 4 में, गुणों की सहायता से किया गया है। विशेषताएँ निम्नलिखित फायदे हैं -
विशेषताओं की मदद से, हम आसानी से देख सकते हैं कि कौन सा डेटा उपलब्ध है, क्योंकि विशेषताएँ दृढ़ता से टाइप की जाती हैं।
हम आसानी से विशेषताओं में निहित जानकारी तक पहुँच सकते हैं।
Mule 4 में एक विशिष्ट संदेश का उदाहरण निम्नलिखित है -
आउटबाउंड
Mule 3 में आउटबाउंड गुण अतिरिक्त डेटा भेजने के लिए Mule कनेक्टर्स और ट्रांसपोर्ट द्वारा स्पष्ट रूप से निर्दिष्ट होना चाहिए। लेकिन Mule 4 में, उनमें से प्रत्येक को अलग से सेट किया जा सकता है, उनमें से प्रत्येक के लिए एक DataWeave अभिव्यक्ति का उपयोग करके। यह मुख्य प्रवाह में कोई दुष्प्रभाव नहीं पैदा करता है।
उदाहरण के लिए, नीचे DataWeave अभिव्यक्ति एक HTTP अनुरोध करेगी और हेडर और क्वेरी पैरामीटर को संदेश गुण सेट करने की आवश्यकता के बिना उत्पन्न करती है। यह नीचे दिए गए कोड में दिखाया गया है -
<http:request path = "M_issue" config-ref="http" method = "GET">
<http:headers>#[{'path':'input/issues-list.json'}]</http:headers>
<http:query-params>#[{'provider':'memory-provider'}]</http:query-params>
</http:request>
संदेश प्रोसेसर
एक बार जब एक संदेश स्रोत से एक संदेश प्राप्त होता है, तो संदेश प्रोसेसर का काम शुरू होता है। एक प्रवाह के माध्यम से संदेश को संसाधित करने के लिए खच्चर एक या अधिक संदेश प्रोसेसर का उपयोग करता है। संदेश प्रोसेसर का मुख्य कार्य संदेश को रूपांतरित करना, फ़िल्टर करना, समृद्ध करना और संसाधित करना है क्योंकि यह खच्चर के प्रवाह से गुजरता है।
खच्चर प्रोसेसर का वर्गीकरण
निम्नलिखित कार्यों के आधार पर खच्चर प्रोसेसर की श्रेणियां हैं -
Connectors- ये संदेश प्रोसेसर डेटा भेजते और प्राप्त करते हैं। वे मानक प्रोटोकॉल या तृतीय-पक्ष API के माध्यम से बाहरी डेटा स्रोतों में डेटा प्लग भी करते हैं।
Components - ये संदेश प्रोसेसर प्रकृति में लचीले होते हैं और जावा, जावास्क्रिप्ट, ग्रूवी, पायथन या रूबी जैसी विभिन्न भाषाओं में कार्यान्वित व्यावसायिक तर्क देते हैं।
Filters - वे संदेशों को फ़िल्टर करते हैं और विशिष्ट मानदंडों के आधार पर केवल विशिष्ट संदेशों को एक प्रवाह में संसाधित करने के लिए जारी रखने की अनुमति देते हैं।
Routers - इस मैसेज प्रोसेसर का इस्तेमाल मैसेज के प्रवाह को रूट, रीसेंसेसिंग या स्प्लिट करने के लिए किया जाता है।
Scopes - हे मूल रूप से एक प्रवाह के भीतर ठीक-ठीक व्यवहार को परिभाषित करने के उद्देश्य से कोड के स्निपेट लपेटते हैं।
Transformers - ट्रांसफॉर्मर की भूमिका सिस्टम के बीच संचार की सुविधा के लिए संदेश पेलोड प्रकार और डेटा प्रारूप में परिवर्तित करना है।
Business Events - वे मूल प्रदर्शन संकेतकों से जुड़े डेटा को मूल रूप से कैप्चर करते हैं।
Exception strategies - ये संदेश प्रोसेसर संदेश प्रसंस्करण के दौरान होने वाली किसी भी प्रकार की त्रुटियों को संभालते हैं।
खच्चर की सबसे महत्वपूर्ण क्षमताओं में से एक यह है कि यह घटकों के साथ रूटिंग, ट्रांसफॉर्मिंग और प्रोसेसिंग कर सकता है, क्योंकि विभिन्न तत्वों को मिलाने वाले खच्चर एप्लिकेशन की कॉन्फ़िगरेशन फ़ाइल आकार में बहुत बड़ी है।
मूले द्वारा प्रदान किए गए विन्यास पैटर्न के प्रकार निम्नलिखित हैं -
- सरल सेवा पैटर्न
- Bridge
- Validator
- Http प्रॉक्सी
- WS प्रॉक्सी
घटक को कॉन्फ़िगर करना
Anypoint स्टूडियो में, हम एक घटक को कॉन्फ़िगर करने के लिए निम्न चरणों का पालन कर सकते हैं -
Step 1
हमें अपने खच्चर आवेदन में जिस घटक का उपयोग करना चाहते हैं उसे खींचने की आवश्यकता है। उदाहरण के लिए, यहाँ हम निम्नानुसार HTTP श्रोता घटक का उपयोग करते हैं -
Step 2
अगला, कॉन्फ़िगरेशन विंडो प्राप्त करने के लिए घटक पर डबल क्लिक करें। HTTP श्रोता के लिए, इसे नीचे दिखाया गया है -
Step 3
हम अपनी परियोजना की आवश्यकता के अनुसार घटक को कॉन्फ़िगर कर सकते हैं। उदाहरण के लिए कहें, हमने HTTP श्रोता घटक के लिए किया -
मुख्य घटक खच्चर ऐप में कार्य प्रवाह के महत्वपूर्ण भवन ब्लॉकों में से एक हैं। इन मुख्य घटकों द्वारा एक खच्चर घटना को संसाधित करने का तर्क प्रदान किया जाता है। इन मुख्य घटकों को एक्सेस करने के लिए, एनपॉइंट स्टूडियो में, आप नीचे दिखाए गए अनुसार कोर पैलेट से कोर पर क्लिक कर सकते हैं -
निम्नलिखित विभिन्न हैं core components and their working in Mule 4 -
कस्टम बिजनेस इवेंट
इस कोर कंपोनेंट का उपयोग फ्लो के साथ-साथ मैसेज प्रोसिजर्स के बारे में जानकारी के संग्रह के लिए किया जाता है, जो Mule ऐप में बिजनेस ट्रांजेक्शन को हैंडल करते हैं। दूसरे शब्दों में, हम अपने काम के प्रवाह में निम्नलिखित जोड़ने के लिए कस्टम बिजनेस इवेंट घटक का उपयोग कर सकते हैं -
- Metadata
- प्रमुख प्रदर्शन संकेतक (KPI)
KPI कैसे जोड़ें?
खच्चर ऐप में हमारे प्रवाह में KPI जोड़ने के लिए निम्नलिखित कदम हैं -
Step 1 - खच्चर का पालन करें Palette → Core → Components → Custom Business Event, अपने खच्चर ऐप में काम करने के लिए कस्टम बिजनेस इवेंट घटक को जोड़ने के लिए।
Step 2 - इसे खोलने के लिए घटक पर क्लिक करें।
Step 3 - अब, हमें प्रदर्शन नाम और ईवेंट नाम के लिए मान प्रदान करने की आवश्यकता है।
Step 4 - संदेश पेलोड से जानकारी प्राप्त करने के लिए, निम्नानुसार KPI जोड़ें -
KPI के लिए एक नाम (कुंजी) दें ( ट्रैकिंग: मेटा-डेटा तत्व) और एक मान। नाम का उपयोग रनटाइम मैनेजर के खोज इंटरफ़ेस में किया जाएगा।
एक मूल्य दें जो किसी भी नियम की अभिव्यक्ति हो सकती है।
उदाहरण
निम्नलिखित तालिका में नाम और मूल्य के साथ KPI की सूची शामिल है -
नाम | अभिव्यक्ति / मूल्य |
---|---|
छात्र रोलनो | # [पेलोड [ 'RollNo']] |
छात्र का नाम | # [पेलोड [ 'नाम']] |
गतिशील मूल्यांकन
इस कोर घटक का उपयोग खच्चर ऐप में स्क्रिप्ट का चयन करने के लिए किया जाता है। हम ट्रांसफॉर्म मैसेज कंपोनेंट के जरिए हार्डकोर स्क्रिप्ट का भी इस्तेमाल कर सकते हैं लेकिन डायनामिक इवैल्यूएशन कंपोनेंट का इस्तेमाल करना बेहतर तरीका है। यह मुख्य घटक निम्नानुसार काम करता है -
- सबसे पहले, यह एक अभिव्यक्ति का मूल्यांकन करता है जिसका परिणाम दूसरी स्क्रिप्ट में होना चाहिए।
- फिर यह अंतिम परिणाम के लिए उस स्क्रिप्ट का मूल्यांकन करता है।
इस तरह, यह हमें स्क्रिप्ट को हार्डकोड करने के बजाय गतिशील रूप से चुनने की अनुमति देता है।
उदाहरण
आईडी क्वेरी पैरामीटर के माध्यम से डेटाबेस से एक स्क्रिप्ट का चयन करने और माइस्क्रिप्ट नामक एक चर में उस स्क्रिप्ट को संग्रहीत करने का एक उदाहरण निम्नलिखित है । अब, डायनामिक-मूल्यांकन घटक स्क्रिप्ट को लागू करने के लिए चर का उपयोग करेगा ताकि यह एक नाम चर को जोड़ सकेUName क्वेरी पैरामीटर।
प्रवाह का XML विन्यास नीचे दिया गया है -
<flow name = "DynamicE-example-flow">
<http:listener config-ref = "HTTP_Listener_Configuration" path = "/"/>
<db:select config-ref = "dbConfig" target = "myScript">
<db:sql>#["SELECT script FROM SCRIPTS WHERE ID =
$(attributes.queryParams.Id)"]
</db:sql>
</db:select>
<ee:dynamic-evaluate expression = "#[vars.myScript]">
<ee:parameters>#[{name: attributes.queryParams.UName}]</ee:parameters>
</ee:dynamic-evaluate>
</flow>
स्क्रिप्ट संदेश, पेलोड, संस्करण या विशेषताओं जैसे संदर्भ चर का उपयोग कर सकती है। हालाँकि, यदि आप कस्टम संदर्भ चर जोड़ना चाहते हैं, तो आपको कुंजी-मूल्य जोड़े का एक सेट प्रदान करना होगा।
गतिशील मूल्यांकन का विन्यास
निम्नलिखित तालिका डायनामिक मूल्यांकन घटक को कॉन्फ़िगर करने का एक तरीका प्रदान करती है -
मैदान | मूल्य | विवरण | उदाहरण |
---|---|---|---|
अभिव्यक्ति | डेटाविवे अभिव्यक्ति | यह अंतिम स्क्रिप्ट में मूल्यांकन किए जाने वाले अभिव्यक्ति को निर्दिष्ट करता है। | अभिव्यक्ति = "# [vars.generateOrderScript]" |
मापदंडों | डेटाविवे अभिव्यक्ति | यह कुंजी-मूल्य जोड़े निर्दिष्ट करता है। | # [{जॉइनर: 'और', आईडी: पेलोड.सुअर.आईडी}] |
प्रवाह संदर्भ घटक
यदि आप खच्चर घटना को किसी अन्य प्रवाह या उप-प्रवाह और उसी खच्चर ऐप के भीतर वापस भेजना चाहते हैं, तो प्रवाह संदर्भ घटक सही विकल्प है।
विशेषताएँ
इस मुख्य घटक की विशेषताएं निम्नलिखित हैं -
यह मुख्य घटक हमें वर्तमान प्रवाह में एकल घटक की तरह पूरे संदर्भित प्रवाह का इलाज करने की अनुमति देता है।
यह असतत और पुन: प्रयोज्य इकाइयों में खच्चर के अनुप्रयोग को तोड़ता है। उदाहरण के लिए, एक प्रवाह नियमित आधार पर फाइलों को सूचीबद्ध कर रहा है। यह एक और प्रवाह को संदर्भित कर सकता है जो सूची ऑपरेशन के आउटपुट को संसाधित करता है।
इस तरह, पूरे प्रोसेसिंग चरणों को लागू करने के बजाय, हम फ़्लो रेफ़रेंस को जोड़ सकते हैं जो प्रोसेसिंग फ़्लो की ओर इशारा करता है। नीचे दिए गए स्क्रीनशॉट से पता चलता है कि फ्लो रेफरेंस कोर कंपोनेंट नाम के सब-फ्लो की ओर इशारा कर रहा हैProcessFiles।
काम कर रहे
निम्नलिखित आरेख की मदद से फ्लो रेफ घटक के कार्य को समझा जा सकता है -
आरेख म्यूल एप्लिकेशन में प्रोसेसिंग ऑर्डर दिखाता है जब एक प्रवाह एक ही एप्लिकेशन में किसी अन्य प्रवाह को संदर्भित करता है। जब खच्चर एप्लिकेशन में मुख्य कार्य प्रवाह शुरू हो जाता है, तो खच्चर घटना प्रवाह संदर्भ में पहुंचने तक सभी प्रवाह से गुजरती है और प्रवाह को निष्पादित करती है।
फ्लो रेफरेंस तक पहुंचने के बाद, खच्चर इवेंट शुरू से अंत तक संदर्भित प्रवाह को निष्पादित करता है। एक बार जब Mule इवेंट Ref Flow को निष्पादित करता है, तो यह मुख्य प्रवाह पर वापस आ जाता है।
उदाहरण
बेहतर समझ के लिए, let us use this component in Anypoint Studio। इस उदाहरण में, हम एक संदेश प्राप्त करने के लिए HTTP श्रोता ले जा रहे हैं, जैसा कि हमने पिछले अध्याय में किया था। तो, हम घटक को ड्रैग और ड्रॉप कर सकते हैं और कॉन्फ़िगर कर सकते हैं। लेकिन इस उदाहरण के लिए, हमें एक उप-प्रवाह घटक जोड़ना होगा और उसके नीचे पेलोड घटक सेट करना होगा, जैसा कि नीचे दिखाया गया है -
अगला, हमें कॉन्फ़िगर करने की आवश्यकता है Set Payload, उस पर डबल क्लिक करके। यहाँ हम मूल्य दे रहे हैं, "उप प्रवाह निष्पादित" जैसा कि नीचे दिखाया गया है -
एक बार सफलतापूर्वक उप-प्रवाह घटक को कॉन्फ़िगर करने के बाद, हमें मुख्य प्रवाह के सेट पेलोड के बाद सेट करने के लिए फ्लो संदर्भ घटक की आवश्यकता होती है, जिसे हम नीचे दिखाए गए अनुसार खच्चर पैलेट से खींच और छोड़ सकते हैं -
अगला, फ्लो रेफरेंस कंपोनेंट को कॉन्फ़िगर करते समय, हमें जेनेरिक टैब के तहत फ्लो नेम चुनने की जरूरत है, जैसा कि नीचे दिखाया गया है -
अब, इस एप्लिकेशन को सहेजें और चलाएँ। इसे जांचने के लिए, POSTMAN पर जाएं और टाइप करेंhttp:/localhost:8181/FirstAPP URL बार में, और आपको संदेश मिलेगा, सब फ्लो निष्पादित।
लकड़हारा घटक
मुख्य घटक जिसे लकड़हारा कहा जाता है, हमें त्रुटि संदेश, स्थिति सूचना, पेलोड, आदि जैसे महत्वपूर्ण जानकारी को लॉग इन करके हमारे खच्चर के आवेदन पर नजर रखने और डिबग करने में मदद करता है, AnyPoint स्टूडियो में, वे दिखाई देते हैं Console।
लाभ
लकड़हारे घटक के कुछ फायदे निम्नलिखित हैं -
- हम इस कोर घटक को काम के प्रवाह में कहीं भी जोड़ सकते हैं।
- हम इसे हमारे द्वारा निर्दिष्ट स्ट्रिंग को लॉग करने के लिए कॉन्फ़िगर कर सकते हैं।
- हम इसे हमारे द्वारा लिखी गई DataWeave अभिव्यक्ति के आउटपुट में कॉन्फ़िगर कर सकते हैं।
- हम इसे स्ट्रिंग्स और अभिव्यक्तियों के किसी भी संयोजन से भी कॉन्फ़िगर कर सकते हैं।
उदाहरण
नीचे दिया गया उदाहरण ब्राउज़र में सेट पेलोड में "हैलो वर्ल्ड" संदेश प्रदर्शित करता है और संदेश भी लॉग करता है।
उपरोक्त उदाहरण में प्रवाह का XML विन्यास निम्नलिखित है -
<http:listener-config name = "HTTP_Listener_Configuration" host = "localhost" port = "8081"/>
<flow name = "mymuleprojectFlow">
<http:listener config-ref="HTTP_Listener_Configuration" path="/"/>
<set-payload value="Hello World"/>
<logger message = "#[payload]" level = "INFO"/>
</flow>
संदेश घटक स्थानांतरित करें
ट्रांसफ़र मैसेज कंपोनेंट, जिसे ट्रांसफ़र कंपोनेंट भी कहा जाता है, हमें इनपुट डेटा को नए आउटपुट फॉर्मेट में बदलने की अनुमति देता है।
परिवर्तन के निर्माण के तरीके
हम निम्नलिखित दो तरीकों की मदद से अपने परिवर्तन का निर्माण कर सकते हैं -
Drag-and-Drop Editor (Graphical View)- यह हमारे परिवर्तन का निर्माण करने वाला पहला और सबसे अधिक इस्तेमाल किया जाने वाला तरीका है। इस पद्धति में, हम आने वाले डेटा संरचना के तत्वों को खींचने और छोड़ने के लिए इस घटक के दृश्य मैपर का उपयोग कर सकते हैं। उदाहरण के लिए, निम्नलिखित आरेख में, दो पेड़ दृश्य इनपुट और आउटपुट की अपेक्षित मेटाडेटा संरचना दिखाते हैं। आउटपुट फ़ील्ड से इनपुट कनेक्ट करने वाली लाइनें दो ट्री दृश्यों के बीच मैपिंग का प्रतिनिधित्व करती हैं।
Script View- परिवर्तन के दृश्य मानचित्रण को डेटा कोड की मदद से भी देखा जा सकता है, जो खच्चर कोड की भाषा है। हम कुछ उन्नत परिवर्तनों के लिए कोडिंग कर सकते हैं जैसे एकत्रीकरण, सामान्यीकरण, समूहन, जुड़ना, विभाजन, धुरीकरण और फ़िल्टरिंग। उदाहरण नीचे दिया गया है -
यह मुख्य घटक मूल रूप से एक चर, एक विशेषता या संदेश पेलोड के लिए इनपुट और आउटपुट मेटाडेटा को स्वीकार करता है। हम निम्नलिखित के लिए प्रारूप-विशिष्ट संसाधन प्रदान कर सकते हैं -
- CSV
- Schema
- फ्लैट फ़ाइल स्कीमा
- JSON
- वस्तु वर्ग
- सरल प्रकार
- XML स्कीमा
- एक्सेल कॉलम नाम और प्रकार
- निश्चित चौड़ाई कॉलम नाम और प्रकार
एंडपॉइंट्स में मूल रूप से उन घटकों को शामिल किया जाता है जो खच्चर एप्लिकेशन के काम के प्रवाह में प्रसंस्करण को ट्रिगर या आरंभ करते हैं। वे कहते हैंSource Anypoint स्टूडियो में और Triggersखच्चर के डिजाइन केंद्र में। Mule 4 में एक महत्वपूर्ण समापन बिंदु हैScheduler component।
अनुसूचक समापन बिंदु
यह घटक समय-आधारित स्थितियों पर काम करता है, जिसका अर्थ है, यह हमें एक प्रवाह को ट्रिगर करने में सक्षम बनाता है जब भी समय-आधारित स्थिति पूरी होती है। उदाहरण के लिए, एक अनुसूचक 10 सेकंड का कहना है कि एक खच्चर काम प्रवाह शुरू करने के लिए एक घटना को गति प्रदान कर सकता है। हम शेड्यूलर एंडपॉइंट को ट्रिगर करने के लिए लचीली क्रोन अभिव्यक्ति का भी उपयोग कर सकते हैं।
शेड्यूलर के बारे में महत्वपूर्ण बिंदु
शेड्यूलर ईवेंट का उपयोग करते समय, हमें नीचे दिए गए कुछ महत्वपूर्ण बिंदुओं का ध्यान रखना चाहिए -
शेड्यूलर एंडपॉइंट मशीन के टाइम-ज़ोन का अनुसरण करता है जहाँ पर Mule runtime चल रहा है।
मान लीजिए कि यदि क्लाउड एप्लिकेशन में एक खच्चर एप्लिकेशन चल रहा है, तो शेड्यूलर उस क्षेत्र के समय-क्षेत्र का पालन करेगा जिसमें क्लाउडहब कार्यकर्ता चल रहा है।
किसी भी समय, शेड्यूलर समापन बिंदु द्वारा ट्रिगर किया गया केवल एक प्रवाह सक्रिय हो सकता है।
खच्चर रनटाइम क्लस्टर में, शेड्यूलर समापन बिंदु केवल प्राथमिक नोड पर चलता है या चलाता है।
शेड्यूलर को कॉन्फ़िगर करने के तरीके
जैसा कि ऊपर चर्चा की गई है, हम एक अनुसूचक समापन बिंदु को एक निश्चित अंतराल पर चालू करने के लिए कॉन्फ़िगर कर सकते हैं या हम क्रोन अभिव्यक्ति भी दे सकते हैं।
शेड्यूलर को कॉन्फ़िगर करने के लिए पैरामीटर (निश्चित अंतराल के लिए)
नियमित अंतराल पर प्रवाह को गति देने के लिए अनुसूचक निर्धारित करने के लिए निम्नलिखित पैरामीटर हैं -
Frequency- यह मूल रूप से वर्णन करता है कि किस आवृत्ति पर शेड्यूलर समापन बिंदु खच्चर के प्रवाह को गति देगा। इसके लिए समय की इकाई को समय इकाई क्षेत्र से चुना जा सकता है। यदि आप इसके लिए कोई मान प्रदान नहीं करते हैं, तो यह डिफ़ॉल्ट मान का उपयोग करेगा जो 1000 है। दूसरी तरफ, यदि आप 0 या एक नकारात्मक मान प्रदान करते हैं, तो यह डिफ़ॉल्ट मान का भी उपयोग करता है।
Start Delay- आवेदन शुरू होने के बाद पहली बार खच्चर के प्रवाह को ट्रिगर करने से पहले हमें इंतजार करना चाहिए। प्रारंभ विलंब का मान आवृत्ति के समान समय की इकाई में व्यक्त किया जाता है। इसका डिफ़ॉल्ट मान 0 है।
Time Unit- यह आवृत्ति और प्रारंभ विलंब दोनों के लिए समय इकाई का वर्णन करता है। समय इकाई के संभावित मूल्य मिलिसेकंड, सेकंड, मिनट, घंटे, दिन हैं। डिफ़ॉल्ट मान Milliseconds है।
एक शेड्यूलर (क्रोन अभिव्यक्ति के लिए) कॉन्फ़िगर करने के लिए पैरामीटर
दरअसल, क्रोन एक मानक है जिसका उपयोग समय और तारीख की जानकारी के वर्णन के लिए किया जाता है। यदि आप समयबद्धक ट्रिगर बनाने के लिए लचीली क्रॉन अभिव्यक्ति का उपयोग करते हैं, तो शेड्यूलर समापन बिंदु हर दूसरे का ट्रैक रखता है और जब भी क्वार्ट्ज क्रोन अभिव्यक्ति समय-तिथि सेटिंग से मेल खाती है, तो एक खच्चर घटना बनाता है। क्रोन अभिव्यक्ति के साथ, घटना को केवल एक बार या नियमित अंतराल पर ट्रिगर किया जा सकता है।
निम्नलिखित तालिका छह आवश्यक सेटिंग्स की तारीख-समय की अभिव्यक्ति देती है -
गुण | मूल्य |
---|---|
सेकंड | 0-59 |
मिनट | 0-59 |
घंटे | 0-23 |
महीने का दिन | 1-31 |
महीना | 1-12 या JAN-DEC |
हफ्ते का दिन | 1-7 या SUN-SAT |
शेड्यूलर समापन बिंदु द्वारा समर्थित क्वार्ट्ज क्रोन अभिव्यक्तियों के कुछ उदाहरण नीचे दिए गए हैं -
½ * * * * ? - इसका मतलब है कि शेड्यूलर हर दिन, हर दिन 2 सेकंड चलाता है।
0 0/5 16 ** ? - इसका मतलब है कि शेड्यूलर हर 5 मिनट पर शाम 4 बजे से शुरू होता है और हर दिन 4:55 बजे समाप्त होता है।
1 1 1 1, 5 * ? - इसका मतलब है कि अनुसूचक हर साल जनवरी के पहले दिन और अप्रैल के पहले दिन को चलाता है।
उदाहरण
निम्न कोड हर सेकंड "हाय" संदेश लॉग करता है -
<flow name = "cronFlow" doc:id = "ae257a5d-6b4f-4006-80c8-e7c76d2f67a0">
<doc:name = "Scheduler" doc:id = "e7b6scheduler8ccb-c6d8-4567-87af-aa7904a50359">
<scheduling-strategy>
<cron expression = "* * * * * ?" timeZone = "America/Los_Angeles"/>
</scheduling-strategy>
</scheduler>
<logger level = "INFO" doc:name = "Logger"
doc:id = "e2626dbb-54a9-4791-8ffa-b7c9a23e88a1" message = '"hi"'/>
</flow>
प्रवाह नियंत्रण (राउटर)
फ्लो कंट्रोल घटक का मुख्य कार्य इनपुट खच्चर घटना को लेना है और इसे घटकों के एक या अधिक अलग-अलग अनुक्रमों तक ले जाना है। यह मूल रूप से इनपुट खच्चर घटना को घटकों के अन्य अनुक्रम (नों) तक पहुंचा रहा है। इसलिए, इसे रूटर्स भी कहा जाता है। चॉइस कंट्रोल घटक के तहत चॉइस और स्कैटर-गेदर राउटर सबसे ज्यादा इस्तेमाल किए जाने वाले रूटर्स हैं।
राउटर का चुनाव करें
जैसा कि नाम से पता चलता है, यह राउटर डेटाविवे तर्क को दो या अधिक मार्गों में से एक को चुनने के लिए लागू करता है। जैसा कि पहले चर्चा की गई है, प्रत्येक मार्ग खच्चर घटना प्रोसेसर का एक अलग अनुक्रम है। हम राउटर के रूप में चॉइस राउटर को परिभाषित कर सकते हैं जो डायनामिक रूप से संदेश सामग्री के मूल्यांकन के लिए उपयोग किए जाने वाले डेटाविवे भावों के एक सेट के अनुसार प्रवाह के माध्यम से संदेश देता है।
चॉइस राउटर का योजनाबद्ध आरेख
चॉइस राउटर का उपयोग करने का प्रभाव सिर्फ प्रवाह या ए के लिए सशर्त प्रसंस्करण को जोड़ने जैसा है if/then/elseअधिकांश प्रोग्रामिंग भाषाओं में कोड ब्लॉक। चॉइस राउटर के योजनाबद्ध आरेख के बाद, तीन विकल्प हैं। उनमें से, एक डिफ़ॉल्ट राउटर है।
तितर-बितर रूटर
एक और सबसे ज्यादा इस्तेमाल किया जाने वाला रूटिंग इवेंट प्रोसेसर है Scatter-Gather component। जैसा कि इसके नाम का अर्थ है, यह स्कैटर (कॉपी) और इकट्ठा (समेकन) के मूल सिद्धांतों पर काम करता है। हम निम्नलिखित दो बिंदुओं की सहायता से इसके कार्य को समझ सकते हैं -
सबसे पहले, यह राउटर दो या अधिक समानांतर मार्गों के लिए एक खच्चर घटना को कॉपी (स्कैटर) करता है। शर्त यह है कि प्रत्येक मार्ग में एक या अधिक इवेंट प्रोसेसर का क्रम होना चाहिए जो कि उप-प्रवाह की तरह है। इस मामले में प्रत्येक मार्ग एक अलग थ्रेड का उपयोग करके एक खच्चर घटना पैदा करेगा। प्रत्येक खच्चर घटना का अपना पेलोड, विशेषताओं के साथ-साथ चर भी होगा।
अगला, यह राउटर प्रत्येक मार्ग से निर्मित खच्चर की घटनाओं को इकट्ठा करता है और फिर उन्हें एक साथ एक नए खच्चर घटना में समेकित करता है। इसके बाद, यह अगले इवेंट प्रोसेसर के लिए इस समेकित खच्चर घटना को पारित करता है। यहां शर्त यह है कि एसजी राउटर अगले इवेंट प्रोसेसर के लिए एक समेकित खच्चर घटना को पारित करेगा, जब प्रत्येक मार्ग सफलतापूर्वक पूरा हो जाएगा।
स्कैटर-इकट्ठा राउटर के योजनाबद्ध आरेख
चार इवेंट प्रोसेसर वाले स्कैटर-गैदर राउटर का योजनाबद्ध आरेख निम्नलिखित है। यह समानांतर में हर मार्ग को निष्पादित करता है और क्रमिक रूप से नहीं।
Scatter-Gather Router द्वारा हैंडलिंग में त्रुटि
सबसे पहले, हमें उस तरह की त्रुटि पर ज्ञान होना चाहिए जो स्कैटर-इकट्ठा घटक के भीतर उत्पन्न हो सकती है। किसी भी प्रकार की त्रुटि को फेंकने के लिए Scatter-Gather घटक के प्रमुख प्रोसेसर के भीतर कोई त्रुटि उत्पन्न हो सकती हैMule: COMPOSITE_ERROR। यह त्रुटि SG घटक द्वारा फेंके जाने के बाद ही हर मार्ग में विफल या पूर्ण हो जाएगी।
इस त्रुटि प्रकार को संभालने के लिए, ए try scopeस्कैटर-गैदर घटक के प्रत्येक मार्ग में उपयोग किया जा सकता है। यदि त्रुटि सफलतापूर्वक नियंत्रित हो जाती हैtry scope, तो मार्ग सुनिश्चित करने के लिए एक खच्चर घटना उत्पन्न करने में सक्षम हो जाएगा।
ट्रान्सफ़ॉर्मर
मान लीजिए कि अगर हम किसी खच्चर की घटना का एक हिस्सा सेट या निकालना चाहते हैं, तो ट्रांसफार्मर घटक सबसे अच्छा विकल्प है। ट्रांसफार्मर घटक निम्न प्रकार के होते हैं -
चर ट्रांसफार्मर निकालें
जैसा कि नाम का अर्थ है, यह घटक एक चर नाम लेता है और खच्चर घटना से उस चर को हटा देता है।
चर ट्रांसफार्मर को हटाने का विन्यास
नीचे दी गई तालिका चर ट्रांसफार्मर को हटाते समय खेतों के नाम और उनके विवरण पर विचार करती है -
अनु क्रमांक | क्षेत्र और स्पष्टीकरण |
---|---|
1 | Display Name (doc:name) हम अपने खच्चर के काम के प्रवाह में इस घटक के लिए एक अद्वितीय नाम प्रदर्शित करने के लिए इसे अनुकूलित कर सकते हैं। |
2 | Name (variableName) यह चर को हटाने के नाम का प्रतिनिधित्व करता है। |
पेलोड ट्रांसफार्मर सेट करें
की मदद से set-payloadघटक, हम पेलोड को अपडेट कर सकते हैं, जो संदेश का शाब्दिक स्ट्रिंग या डेटावेव एक्सप्रेशन हो सकता है। जटिल अभिव्यक्तियों या परिवर्तनों के लिए इस घटक का उपयोग करने की अनुशंसा नहीं की जाती है। इसका उपयोग साधारण लोगों के लिए किया जा सकता हैselections।
नीचे दिए गए तालिका में फ़ील्ड के नाम और सेट पेलोड ट्रांसफार्मर को कॉन्फ़िगर करते समय उनके विवरण पर विचार किया गया है -
मैदान | प्रयोग | व्याख्या |
---|---|---|
मान (मान) | अनिवार्य | पेलोड सेट करने के लिए दायर मूल्य की आवश्यकता है। यह पेलोड को सेट करने के तरीके को परिभाषित करने वाले एक शाब्दिक स्ट्रिंग या डेटाविवे अभिव्यक्ति को स्वीकार करेगा। उदाहरण "कुछ स्ट्रिंग" जैसे हैं |
माइम प्रकार (माइम टाइप) | ऐच्छिक | यह वैकल्पिक है लेकिन संदेश के पेलोड को सौंपे गए मूल्य के माइम प्रकार का प्रतिनिधित्व करता है। उदाहरण पाठ / सादे की तरह हैं। |
एन्कोडिंग (एन्कोडिंग) | ऐच्छिक | यह वैकल्पिक भी है, लेकिन संदेश के पेलोड को दिए गए मान के एन्कोडिंग का प्रतिनिधित्व करता है। उदाहरण UTF-8 जैसे हैं। |
हम XML कॉन्फ़िगरेशन कोड के माध्यम से पेलोड सेट कर सकते हैं -
With Static Content - XML कॉन्फ़िगरेशन कोड के बाद स्थैतिक सामग्री का उपयोग करके पेलोड सेट हो जाएगा -
<set-payload value = "{ 'name' : 'Gaurav', 'Id' : '2510' }"
mimeType = "application/json" encoding = "UTF-8"/>
With Expression Content - एक्सएमएल कॉन्फ़िगरेशन कोड के बाद एक्सप्रेशन सामग्री का उपयोग करके पेलोड सेट किया जाएगा -
<set-payload value = "#['Hi' ++ ' Today is ' ++ now()]"/>
उपरोक्त उदाहरण संदेश पेलोड "हाय" के साथ आज की तारीख को जोड़ देगा।
परिवर्तनीय ट्रांसफार्मर सेट करें
की मदद से set variableघटक, हम मानों को संग्रहीत करने के लिए एक चर बना सकते हैं या अपडेट कर सकते हैं जो कि खच्चर एप्लिकेशन के प्रवाह के भीतर उपयोग के लिए सरल शाब्दिक मूल्य जैसे तार, संदेश पेलोड या विशेषता ऑब्जेक्ट हो सकते हैं। जटिल अभिव्यक्तियों या परिवर्तनों के लिए इस घटक का उपयोग करने की अनुशंसा नहीं की जाती है। इसका उपयोग साधारण लोगों के लिए किया जा सकता हैselections।
परिवर्तनशील चर ट्रांसफार्मर को कॉन्फ़िगर करना
नीचे दिए गए तालिका में फ़ील्ड के नाम और सेट पेलोड ट्रांसफार्मर को कॉन्फ़िगर करते समय उनके विवरण पर विचार किया गया है -
मैदान | प्रयोग | व्याख्या |
---|---|---|
चर नाम (चर नाम) | अनिवार्य | इसे दायर करना आवश्यक है और यह चर के नाम का प्रतिनिधित्व करता है। नाम देते समय, नामकरण सम्मेलन का पालन करें जैसे कि इसमें संख्या, वर्ण और अंडरस्कोर होना चाहिए। |
मान (मान) | अनिवार्य | वैरिएबल सेट करने के लिए दायर मूल्य आवश्यक है। यह एक शाब्दिक स्ट्रिंग या डेटाविवे अभिव्यक्ति को स्वीकार करेगा। |
माइम प्रकार (माइम टाइप) | ऐच्छिक | यह वैकल्पिक है लेकिन चर के माइम प्रकार का प्रतिनिधित्व करता है। उदाहरण पाठ / सादे की तरह हैं। |
एन्कोडिंग (एन्कोडिंग) | ऐच्छिक | यह वैकल्पिक भी है लेकिन चर के एन्कोडिंग का प्रतिनिधित्व करता है। उदाहरण आईएसओ 10646 / यूनिकोड (UTF-8) जैसे हैं। |
उदाहरण
नीचे दिए गए उदाहरण से संदेश पेलोड में परिवर्तन होगा -
Variable Name = msg_var
Value = payload in Design center and #[payload] in Anypoint Studio
इसी तरह, नीचे दिए गए उदाहरण से संदेश पेलोड में परिवर्तन होगा -
Variable Name = msg_var
Value = attributes in Design center and #[attributes] in Anypoint Studio.
बाकी वेब सेवा
REST का पूर्ण रूप प्रतिनिधि राज्य अंतरण है जो HTTP से जुड़ा है। इसलिए, यदि आप किसी एप्लिकेशन को विशेष रूप से वेब पर उपयोग करने के लिए डिज़ाइन करना चाहते हैं, तो REST सबसे अच्छा विकल्प है।
उपभोक्ता वेब सेवाएँ
निम्नलिखित उदाहरण में, हम REST घटक और एक सार्वजनिक रेस्टफुल सेवा का उपयोग करेंगे, जो Mule Soft द्वारा प्रदान की गई है, जिसे अमेरिकी उड़ानें विवरण कहा जाता है। इसके विभिन्न विवरण हैं लेकिन हम GET का उपयोग करने जा रहे हैं:http://training-american-ws.cloudhub.io/api/flightsवह सभी उड़ान विवरण वापस कर देगा। जैसा कि पहले चर्चा की गई थी, REST HTTP से बंधी है, इसलिए हमें दो HTTP घटकों की आवश्यकता है - एक है श्रोता और दूसरा है अनुरोध, इस आवेदन के लिए भी। नीचे स्क्रीनशॉट HTTP श्रोता के लिए कॉन्फ़िगरेशन दिखाता है -
कॉन्फ़िगर करना और तर्क पारित करना
HTTP अनुरोध के लिए विन्यास नीचे दिया गया है -
अब, हमारे कार्यक्षेत्र प्रवाह के अनुसार, हमने लकड़हारा ले लिया है ताकि इसे नीचे के रूप में कॉन्फ़िगर किया जा सके -
संदेश टैब में, हम पेलोड को स्ट्रिंग्स में बदलने के लिए कोड लिखते हैं।
अनुप्रयोग का परीक्षण
अब, एप्लिकेशन को सहेजें और चलाएं और नीचे दिखाए गए अनुसार अंतिम आउटपुट की जांच करने के लिए POSTMAN पर जाएं -
आप देख सकते हैं यह REST घटक का उपयोग करके उड़ान विवरण देता है।
SOAP घटक
SOAP का पूर्ण रूप है Simple Object Access Protocol। यह मूल रूप से वेब सेवाओं के कार्यान्वयन में सूचनाओं के आदान-प्रदान के लिए एक मैसेजिंग प्रोटोकॉल विनिर्देश है। इसके बाद, हम वेब सेवाओं का उपयोग करके जानकारी तक पहुंचने के लिए Anypoint Studio में SOAP API का उपयोग करने जा रहे हैं।
SOAP- आधारित वेब सेवाओं का उपभोग करना
इस उदाहरण के लिए, हम सार्वजनिक SOAP सेवा का उपयोग करने जा रहे हैं जिसका नाम देश जानकारी सेवा है जो देश की जानकारी से संबंधित सेवाओं को बनाए रखता है। इसका WSDL पता है:http://www.oorsprong.org/websamples.countryinfo/countryinfoservice.wso?WSDL
सबसे पहले, हमें Mule Palette से अपने कैनवास में SOAP उपभोग को खींचने की आवश्यकता है जैसा कि नीचे दिखाया गया है -
कॉन्फ़िगरेशन और पासिंग तर्क
अगला, हमें नीचे दिए गए उदाहरण के अनुसार HTTP अनुरोध को कॉन्फ़िगर करने की आवश्यकता है -
अब, हमें नीचे दिखाए अनुसार वेब सेवा उपभोक्ता को भी कॉन्फ़िगर करना होगा -
डब्लूएसडीएल स्थान के स्थान पर, हमें डब्लूएसडीएल का वेब पता प्रदान करने की आवश्यकता है, जो ऊपर (इस उदाहरण के लिए) प्रदान किया गया है। एक बार जब आप वेब पता दे देते हैं, तो स्टूडियो स्वयं सेवा, पोर्ट और पते की खोज करेगा। आपको इसे मैन्युअल रूप से प्रदान करने की आवश्यकता नहीं है।
वेब सेवा से प्रतिक्रिया का स्थानांतरण
इसके लिए, हमें खच्चर के प्रवाह में एक लकड़हारा जोड़ना होगा और इसे नीचे दिखाए अनुसार पेलोड देने के लिए कॉन्फ़िगर करना होगा -
अनुप्रयोग का परीक्षण
एप्लिकेशन को सहेजें और चलाएं और अंतिम आउटपुट की जांच के लिए Google Chrome पर जाएं। प्रकारhttp://localhist:8081/helloSOAP (इस उदाहरण के लिए) और यह कोड द्वारा देश का नाम दिखाएगा जैसा कि नीचे स्क्रीनशॉट में दिखाया गया है -
नई खच्चर त्रुटि हैंडलिंग, खच्चर 4 में किए गए सबसे बड़े और प्रमुख परिवर्तनों में से एक है। नई त्रुटि सौंपना जटिल लग सकता है, लेकिन यह बेहतर और अधिक कुशल है। इस अध्याय में, हम खच्चर त्रुटि के घटकों, त्रुटि प्रकार, खच्चर त्रुटि की श्रेणियों और खच्चर त्रुटियों से निपटने के लिए घटकों के बारे में चर्चा करने जा रहे हैं।
खच्चर त्रुटि के घटक
खच्चर त्रुटि खच्चर अपवाद विफलता का परिणाम है निम्नलिखित घटक हैं -
विवरण
यह खच्चर त्रुटि का एक महत्वपूर्ण घटक है जो समस्या के बारे में विवरण देगा। इसकी अभिव्यक्ति इस प्रकार है -
#[error.description]
प्रकार
समस्या को चिह्नित करने के लिए Mule त्रुटि के प्रकार घटक का उपयोग किया जाता है। यह एक त्रुटि हैंडलर के भीतर रूटिंग की भी अनुमति देता है। इसकी अभिव्यक्ति इस प्रकार है -
#[error.errorType]
वजह
खच्चर त्रुटि का कारण घटक अंतर्निहित जावा को फेंकने योग्य देता है जो विफलता का कारण बनता है। इसकी अभिव्यक्ति इस प्रकार है -
#[error.cause]
संदेश
खच्चर त्रुटि का संदेश घटक त्रुटि के संबंध में एक वैकल्पिक संदेश दिखाता है। इसकी अभिव्यक्ति इस प्रकार है -
#[error.errorMessage]
बाल त्रुटियां
मुल त्रुटि का चाइल्ड एरर्स घटक आंतरिक त्रुटियों का एक वैकल्पिक संग्रह देता है। ये आंतरिक त्रुटियां मुख्य रूप से एकत्रित मार्ग त्रुटियों को प्रदान करने के लिए Scatter-Gather जैसे तत्वों द्वारा उपयोग की जाती हैं। इसकी अभिव्यक्ति इस प्रकार है -
#[error.childErrors]
उदाहरण
401 स्थिति कोड के साथ HTTP अनुरोध की विफलता के मामले में, नियम त्रुटियां इस प्रकार हैं -
Description: HTTP GET on resource ‘http://localhost:8181/TestApp’
failed: unauthorized (401)
Type: HTTP:UNAUTHORIZED
Cause: a ResponseValidatorTypedException instance
Error Message: { "message" : "Could not authorize the user." }
अनु क्रमांक | त्रुटि प्रकार और विवरण |
---|---|
1 | TRANSFORMATION यह त्रुटि प्रकार मान को परिवर्तित करते समय हुई त्रुटि को इंगित करता है। परिवर्तन Mule Runtime आंतरिक परिवर्तन है न कि DataWeave रूपांतरण। |
2 | EXPRESSION इस प्रकार की त्रुटि प्रकार इंगित करता है कि एक अभिव्यक्ति का मूल्यांकन करते समय कोई त्रुटि हुई। |
3 | VALIDATION इस प्रकार का त्रुटि प्रकार इंगित करता है कि सत्यापन त्रुटि हुई है। |
4 | DUPLICATE_MESSAGE एक प्रकार की सत्यापन त्रुटि जो तब होती है जब संदेश को दो बार संसाधित किया जाता है। |
5 | REDELIVERY_EXHAUSTED इस प्रकार का त्रुटि प्रकार तब होता है जब किसी संदेश को किसी स्रोत से पुन: प्रकाशित करने का अधिकतम प्रयास समाप्त हो गया हो। |
6 | CONNECTIVITY यह त्रुटि प्रकार कनेक्शन स्थापित करते समय एक समस्या को इंगित करता है। |
7 | ROUTING यह त्रुटि प्रकार एक संदेश को रूट करते समय हुई एक त्रुटि को इंगित करता है। |
8 | SECURITY यह त्रुटि प्रकार इंगित करता है कि एक सुरक्षा त्रुटि हुई। उदाहरण के लिए, अमान्य क्रेडेंशियल प्राप्त हुए। |
9 | STREAM_MAXIMUM_SIZE_EXCEEDED यह त्रुटि प्रकार तब होता है जब अधिकतम आकार एक स्ट्रीम के लिए अनुमति देता है। |
10 | TIMEOUT यह किसी संदेश को संसाधित करते समय समयावधि को इंगित करता है। |
1 1 | UNKNOWN यह त्रुटि प्रकार इंगित करता है कि कोई अनपेक्षित त्रुटि हुई है। |
12 | SOURCE यह प्रवाह के स्रोत में एक त्रुटि की घटना का प्रतिनिधित्व करता है। |
13 | SOURCE_RESPONSE यह एक सफल प्रतिक्रिया को संसाधित करते समय प्रवाह के स्रोत में त्रुटि की घटना का प्रतिनिधित्व करता है। |
उपरोक्त उदाहरण में, आप खच्चर त्रुटि के संदेश घटक को देख सकते हैं ।
त्रुटि प्रकार
आइए इसकी विशेषताओं की मदद से त्रुटि प्रकारों को समझते हैं -
खच्चर त्रुटि प्रकार की पहली विशेषता यह है कि इसमें दोनों शामिल हैं, a namespace and an identifier। यह हमें उनके डोमेन के अनुसार प्रकारों को भेद करने की अनुमति देता है। उपरोक्त उदाहरण में, त्रुटि प्रकार हैHTTP: UNAUTHORIZED।
दूसरी और महत्वपूर्ण विशेषता यह है कि त्रुटि प्रकार का मूल प्रकार हो सकता है। उदाहरण के लिए, त्रुटि प्रकारHTTP: UNAUTHORIZED है MULE:CLIENT_SECURITY माता-पिता के रूप में बदले में एक माता-पिता का नाम भी है MULE:SECURITY। यह विशेषता त्रुटि प्रकार को अधिक वैश्विक आइटम के विनिर्देश के रूप में स्थापित करती है।
प्रकार की त्रुटि
निम्नलिखित श्रेणियां हैं जिनके अंतर्गत सभी त्रुटियां आती हैं -
कोई भी
इस श्रेणी के अंतर्गत त्रुटियाँ एक प्रवाह में हो सकने वाली त्रुटियाँ हैं। वे इतने गंभीर नहीं हैं और आसानी से नियंत्रित किए जा सकते हैं।
नाजुक
इस श्रेणी की त्रुटियां गंभीर त्रुटियां हैं जिन्हें संभाला नहीं जा सकता है। इस श्रेणी के अंतर्गत त्रुटि प्रकारों की सूची निम्नलिखित है -
अनु क्रमांक | त्रुटि प्रकार और विवरण |
---|---|
1 | OVERLOAD यह त्रुटि प्रकार ओवरलोडिंग की समस्या के कारण हुई त्रुटि को इंगित करता है। इस मामले में, निष्पादन को अस्वीकार कर दिया जाएगा। |
2 | FATAL_JVM_ERROR इस प्रकार की त्रुटि प्रकार एक घातक त्रुटि की घटना को इंगित करता है। उदाहरण के लिए, स्टैक ओवरफ्लो। |
कस्टम त्रुटि प्रकार
कस्टम त्रुटि प्रकार वे त्रुटियां हैं जो हमारे द्वारा परिभाषित की जाती हैं। उन्हें मैपिंग करते समय या त्रुटियों को उठाते समय परिभाषित किया जा सकता है। हमें इन त्रुटि प्रकारों के लिए एक विशिष्ट कस्टम नेमस्पेस देना होगा, जो उन्हें Mule एप्लिकेशन के भीतर अन्य मौजूदा त्रुटि प्रकारों से अलग करने के लिए है। उदाहरण के लिए, HTTP का उपयोग करके खच्चर एप्लिकेशन में, हम HTTP को कस्टम त्रुटि प्रकार के रूप में उपयोग नहीं कर सकते हैं।
खच्चर त्रुटि की श्रेणियाँ
व्यापक अर्थ में, खच्चर में त्रुटियों को दो श्रेणियों में विभाजित किया जा सकता है, Messaging Errors and System Errors।
मैसेजिंग एरर
खच्चर त्रुटि की यह श्रेणी खच्चर के प्रवाह से संबंधित है। जब भी किसी खच्चर के प्रवाह में कोई समस्या आती है, तो खच्चर एक मैसेजिंग त्रुटि को फेंक देता है। हम सेट कर सकते हैंOn Error इन खच्चर त्रुटियों को संभालने के लिए त्रुटि हैंडलर घटक के अंदर घटक।
सिस्टम में गड़बड़ी
सिस्टम त्रुटि सिस्टम स्तर पर होने वाले अपवाद को इंगित करता है। यदि कोई खच्चर घटना नहीं है, तो सिस्टम त्रुटि हैंडलर द्वारा सिस्टम त्रुटि को नियंत्रित किया जाता है। निम्न प्रकार के अपवाद एक सिस्टम त्रुटि हैंडलर द्वारा संभालते हैं -
- अपवाद जो किसी एप्लिकेशन स्टार्ट-अप के दौरान होता है।
- अपवाद जो तब होता है जब किसी बाहरी सिस्टम का कनेक्शन विफल हो जाता है।
यदि सिस्टम त्रुटि होती है, तो खच्चर पंजीकृत श्रोताओं को एक त्रुटि सूचना भेजता है। यह त्रुटि भी लॉग करता है। दूसरी ओर, एक कनेक्शन विफलता के कारण त्रुटि होने पर, खच्चर एक पुनर्संरचना रणनीति निष्पादित करता है।
हैंडलिंग खराबी
त्रुटियों को संभालने के लिए खच्चर के पास दो त्रुटि हैंडलर हैं -
ऑन-एरर एरर हैंडलर
पहला Mule error handler ऑन-एरर घटक है, जो उन प्रकार की त्रुटियों को परिभाषित करता है जिन्हें वे संभाल सकते हैं। जैसा कि पहले चर्चा की गई है, हम ऑन-एरर घटकों को स्कोप-जैसे एरर हैंडलर घटक के अंदर कॉन्फ़िगर कर सकते हैं। प्रत्येक खच्चर के प्रवाह में केवल एक त्रुटि हैंडलर होता है, लेकिन इस त्रुटि हैंडलर में कई ऑन-एरर स्कोप हो सकते हैं जिनकी हमें आवश्यकता थी। ऑन-एरर घटक की मदद से फ्लो के अंदर खच्चर की त्रुटि से निपटने के लिए कदम इस प्रकार हैं -
सबसे पहले, जब भी कोई खच्चर का प्रवाह एक त्रुटि उठाता है, तो सामान्य प्रवाह निष्पादन बंद हो जाता है।
इसके बाद, प्रक्रिया को स्थानांतरित कर दिया जाएगा Error Handler Component वह पहले से ही है On Error component त्रुटि प्रकारों और भावों का मिलान करने के लिए।
अंत में, त्रुटि हैंडलर घटक पहले त्रुटि को रूट करता है On Error scope यह त्रुटि से मेल खाता है।
खच्चर द्वारा समर्थित दो प्रकार के ऑन-एरर घटक निम्नलिखित हैं -
पर-त्रुटि प्रचार
ऑन-एरर प्रोपेगेट घटक निष्पादित करता है लेकिन त्रुटि को अगले स्तर तक फैलाता है और मालिक के निष्पादन को तोड़ता है। यदि इसे संभाला जाता है तो लेन-देन वापस कर दिया जाएगाOn Error Propagate घटक।
ऑन-एरर जारी
ऑन-एरर प्रोपेगेट घटक की तरह, ऑन-एरर जारी घटक भी लेनदेन को निष्पादित करता है। एकमात्र शर्त यह है, यदि मालिक ने सफलतापूर्वक निष्पादन पूरा कर लिया है, तो यह घटक निष्पादन के परिणाम का उपयोग उसके मालिक के परिणाम के रूप में करेगा। यदि यह ऑन-एरर जारी घटक द्वारा संभाला जाता है तो लेनदेन प्रतिबद्ध होगा।
स्कोप घटक का प्रयास करें
ट्राई स्कोप Mule 4 में उपलब्ध कई नई विशेषताओं में से एक है। यह JAVA के ब्लॉक को ट्राई करने के समान है, जिसमें हम कोड को अपवाद होने की संभावना से जोड़ते थे, ताकि इसे पूरे कोड को तोड़े बिना संभाला जा सके।
हम ट्राई स्कोप में एक या एक से अधिक खच्चर के ईवेंट प्रोसेसर को लपेट सकते हैं और उसके बाद, इस ईवेंट प्रोसेसर्स द्वारा फेंके गए किसी भी अपवाद को पकड़ने की कोशिश करेंगे। ट्राई स्कोप का मुख्य कार्य अपनी त्रुटि हैंडलिंग रणनीति के इर्द-गिर्द घूमता है जो पूरे प्रवाह के बजाय अपने आंतरिक घटक पर त्रुटि से निपटने का समर्थन करता है। इसलिए हमें प्रवाह को एक अलग प्रवाह में निकालने की आवश्यकता नहीं है।
Example
निम्नलिखित प्रयास क्षेत्र के उपयोग का एक उदाहरण है -
लेनदेन को संभालने के लिए कोशिश की गुंजाइश को कॉन्फ़िगर करना
जैसा कि हम जानते हैं, लेन-देन क्रियाओं की एक श्रृंखला है जिसे कभी भी आंशिक रूप से निष्पादित नहीं किया जाना चाहिए। लेन-देन के दायरे में सभी ऑपरेशन एक ही थ्रेड में निष्पादित किए जाते हैं और यदि कोई त्रुटि होती है, तो उसे रोलबैक या कमिट करना चाहिए। हम निम्न तरीके से कोशिश की गुंजाइश को कॉन्फ़िगर कर सकते हैं, ताकि यह लेनदेन के रूप में बच्चे के संचालन का इलाज करे।
INDIFFERENT [Default]- यदि हम कोशिश ब्लॉक पर इस कॉन्फ़िगरेशन को चुनते हैं, तो बच्चे के कार्यों को लेनदेन के रूप में नहीं माना जाएगा। इस स्थिति में, त्रुटि न तो रोलबैक का कारण बनती है और न ही प्रारंभ होती है।
ALWAYS_BEGIN - यह इंगित करता है कि गुंजाइश निष्पादित होने पर हर बार एक नया लेनदेन शुरू किया जाएगा।
BEGIN_OR_JOIN- यह इंगित करता है कि यदि प्रवाह का वर्तमान प्रसंस्करण पहले से ही एक लेनदेन शुरू कर चुका है, तो इसमें शामिल हों। अन्यथा, एक नई शुरुआत करें।
प्रत्येक परियोजना के मामले में, अपवादों के बारे में तथ्य यह है कि वे होने के लिए बाध्य हैं। इसीलिए अपवादों को पकड़ना, वर्गीकृत करना और उन्हें संभालना महत्वपूर्ण है, ताकि सिस्टम / एप्लिकेशन असंगत स्थिति में न छोड़े। एक डिफ़ॉल्ट अपवाद रणनीति है, जो सभी खच्चर अनुप्रयोगों पर अंतर्निहित है। किसी भी लंबित लेन-देन को स्वचालित रूप से रोलबैक करना डिफ़ॉल्ट अपवाद रणनीति है।
खच्चर में अपवाद
असाधारण हैंडलिंग में गहरी गोता लगाने से पहले, हमें यह समझना चाहिए कि तीन बुनियादी सवालों के साथ किस तरह के अपवाद हो सकते हैं, जो किसी गेंदबाज को डिजाइन करते समय एक डेवलपर के पास होने चाहिए।
कौन सा परिवहन महत्वपूर्ण है?
अपवाद हैंडलर को डिजाइन करने से पहले इस प्रश्न की पर्याप्त प्रासंगिकता है क्योंकि सभी परिवहन ट्रांसनेशनलिटी का समर्थन नहीं करते हैं।
File या HTTPलेनदेन का समर्थन नहीं करता है। इसीलिए, यदि इन मामलों में कोई अपवाद होता है, तो हमें इसे मैन्युअल रूप से प्रबंधित करना होगा।
Databasesलेनदेन का समर्थन करें। इस मामले में अपवाद हैंडलर डिजाइन करते समय, हमें यह ध्यान रखना चाहिए कि डेटाबेस लेनदेन स्वचालित रूप से रोलबैक कर सकता है (यदि आवश्यक हो)।
के मामले में REST APIs, हमें ध्यान रखना चाहिए कि उन्हें सही HTTP स्थिति कोड वापस करना चाहिए। उदाहरण के लिए, संसाधन के लिए 404 नहीं मिला।
किस मैसेज एक्सचेंज पैटर्न का उपयोग किया जाना है?
अपवाद हैंडलर डिजाइन करते समय, हमें संदेश विनिमय पैटर्न के बारे में ध्यान रखना चाहिए। समकालिक (अनुरोध-उत्तर) या अतुल्यकालिक (अग्नि-भूल) संदेश पैटर्न हो सकता है।
Synchronous message pattern अनुरोध-उत्तर प्रारूप पर आधारित है, जिसका अर्थ है कि यह पैटर्न एक प्रतिक्रिया की उम्मीद करेगा और जब तक कोई प्रतिक्रिया वापस नहीं होती है या समय समाप्त नहीं होता है तब तक अवरुद्ध रहेगा।
Asynchronous message pattern आग-विस्मृत प्रारूप पर आधारित है, जिसका अर्थ है कि यह पैटर्न मानता है कि अनुरोधों को अंततः संसाधित किया जाएगा।
यह किस प्रकार का अपवाद है?
बहुत सरल नियम यह है कि आप इसके प्रकार के आधार पर अपवाद को संभाल लेंगे। यह जानना बहुत महत्वपूर्ण है कि क्या अपवाद एक प्रणाली / तकनीकी समस्या या व्यावसायिक मुद्दे के कारण होता है?
एक अपवाद हुआ system/technical issue (जैसे कि नेटवर्क आउटेज) को स्वचालित रूप से एक रिट्री तंत्र द्वारा नियंत्रित किया जाना चाहिए।
दूसरी ओर, एक अपवाद हुआ by a business issue (जैसे कि अमान्य डेटा) को रिट्री तंत्र लागू करके हल नहीं किया जाना चाहिए क्योंकि यह अंतर्निहित कारण को ठीक किए बिना पुनर्प्रयास करने के लिए उपयोगी नहीं है।
अपवादों को वर्गीकृत क्यों करें?
जैसा कि हम जानते हैं कि सभी अपवाद समान नहीं हैं, अपवादों को वर्गीकृत करना बहुत महत्वपूर्ण है। उच्च स्तर पर, अपवादों को निम्नलिखित दो प्रकारों में वर्गीकृत किया जा सकता है -
व्यापार अपवाद
व्यापार अपवादों की घटना के मुख्य कारण गलत डेटा या गलत प्रक्रिया प्रवाह हैं। इस तरह के अपवाद आमतौर पर प्रकृति में गैर-पुनर्प्राप्ति योग्य होते हैं और इसलिए यह कॉन्फ़िगर करने के लिए अच्छा नहीं हैrollback। यहां तक कि आवेदन भीretryतंत्र का कोई मतलब नहीं होगा क्योंकि यह अंतर्निहित कारण को ठीक किए बिना पुन: प्रयास करने के लिए उपयोगी नहीं है। इस तरह के अपवादों को संभालने के लिए, प्रसंस्करण को तुरंत रोकना चाहिए, और अपवाद को एक मृत पत्र कतार की प्रतिक्रिया के रूप में वापस भेजा गया। एक अधिसूचना भी संचालन के लिए भेजना चाहिए।
गैर-व्यावसायिक अपवाद
गैर-व्यावसायिक अपवादों की घटना के मुख्य कारण सिस्टम इश्यू या तकनीकी समस्या हैं। इस प्रकार के अपवाद प्रकृति में पुनर्प्राप्त करने योग्य हैं और इसलिए इसे कॉन्फ़िगर करना अच्छा हैretry इन अपवादों को हल करने के लिए तंत्र।
अपवाद हैंडलिंग रणनीतियाँ
खच्चर की निम्नलिखित पाँच अपवाद हैंडलिंग रणनीतियाँ हैं -
डिफ़ॉल्ट अपवाद रणनीति
खच्चर अंतर्निहित रूप से इस रणनीति को खच्चर के प्रवाह पर लागू करता है। यह हमारे प्रवाह में सभी अपवादों को संभाल सकता है, लेकिन कैच, चॉइस या रोलबैक अपवाद रणनीति को जोड़कर इसे ओवरराइड भी किया जा सकता है। यह अपवाद रणनीति किसी भी लंबित लेनदेन को वापस ले लेगी और अपवादों को भी लॉग कर देगी। इस अपवाद रणनीति की एक महत्वपूर्ण विशेषता यह है कि यदि कोई लेनदेन नहीं है तो यह अपवाद को भी लॉग करेगा।
डिफ़ॉल्ट रणनीति होने के नाते, खच्चर इसे लागू करता है जब प्रवाह में कोई त्रुटि होती है। हम AnyPoint स्टूडियो में कॉन्फ़िगर नहीं कर सकते।
रोलबैक अपवाद रणनीति
मान लीजिए अगर त्रुटि को ठीक करने के लिए कोई संभावित समाधान नहीं है तो क्या करें? एक समाधान रोलबैक अपवाद रणनीति का उपयोग करना है जो संदेश को पुन: पेश करने के लिए पेरेंट प्रवाह के इनबाउंड कनेक्टर को एक संदेश भेजने के साथ-साथ लेनदेन को वापस करेगा। यह रणनीति भी बहुत उपयोगी है जब हम किसी संदेश को पुन: प्रस्तुत करना चाहते हैं।
Example
यह रणनीति बैंकिंग लेनदेन पर लागू की जा सकती है जहां चेक / बचत खाते में धन जमा हो रहा है। हम यहां एक रोलबैक अपवाद रणनीति को कॉन्फ़िगर कर सकते हैं क्योंकि अगर लेन-देन के दौरान कोई त्रुटि होती है, तो यह रणनीति प्रसंस्करण को पुन: आरंभ करने के लिए संदेश को वापस प्रवाहित करती है।
अपवाद रणनीति को पकड़ो
यह रणनीति उन सभी अपवादों को पकड़ती है जो इसके मूल प्रवाह के भीतर फेंक दिए जाते हैं। यह मूल प्रवाह द्वारा फेंके गए सभी अपवादों को संसाधित करके Mule की डिफ़ॉल्ट अपवाद रणनीति को ओवरराइड करता है। हम इनबाउंड कनेक्टर्स और पैरेंट फ्लो के अपवादों के प्रचार से बचने के लिए कैच अपवाद रणनीति का उपयोग कर सकते हैं।
यह रणनीति यह भी सुनिश्चित करती है कि अपवाद होने पर प्रवाह द्वारा संसाधित लेन-देन वापस नहीं लुढ़का है।
Example
यह रणनीति उड़ान बुकिंग प्रणाली पर लागू की जा सकती है जिसमें हमारे पास कतार से संदेशों को संसाधित करने के लिए एक प्रवाह है। एक संदेश समृद्ध सीट के असाइनमेंट के लिए संदेश पर एक संपत्ति जोड़ता है और फिर संदेश को दूसरी कतार में भेजता है।
अब यदि इस प्रवाह में कोई त्रुटि होती है, तो संदेश अपवाद को फेंक देगा। यहां, हमारी कैच अपवाद रणनीति एक उपयुक्त संदेश के साथ एक हेडर जोड़ सकती है और उस संदेश को प्रवाह से अगली कतार में धकेल सकती है।
चुनाव अपवाद रणनीति
यदि आप संदेश सामग्री के आधार पर अपवाद को संभालना चाहते हैं, तो विकल्प अपवाद रणनीति सबसे अच्छा विकल्प होगी। इस अपवाद रणनीति का कार्य निम्नानुसार होगा -
- सबसे पहले, यह मूल प्रवाह के भीतर फेंके गए सभी अपवादों को पकड़ता है।
- अगला, यह संदेश सामग्री और अपवाद प्रकार के लिए जाँच करता है।
- और अंत में, यह संदेश को उपयुक्त अपवाद रणनीति के लिए रूट करता है।
च्वाइस अपवाद रणनीति के भीतर परिभाषित कैच या रोलबैक जैसी एक से अधिक अपवाद रणनीति होगी। यदि इस अपवाद रणनीति के तहत कोई रणनीति निर्धारित नहीं की गई है, तो यह संदेश को डिफ़ॉल्ट अपवाद रणनीति में बदल देगा। यह कभी भी कोई कमिटमेंट या रोलबैक या उपभोग की गतिविधियाँ नहीं करता है।
संदर्भ अपवाद रणनीति
यह एक सामान्य अपवाद रणनीति को संदर्भित करता है जिसे एक अलग कॉन्फ़िगरेशन फ़ाइल में परिभाषित किया गया है। मामले में जब कोई संदेश एक अपवाद फेंकता है, तो यह अपवाद रणनीति एक वैश्विक पकड़, रोलबैक या विकल्प अपवाद रणनीति में परिभाषित त्रुटि हैंडलिंग मापदंडों को संदर्भित करेगी। पसंद अपवाद की रणनीति की तरह, यह कभी भी कोई प्रतिबद्ध या रोलबैक नहीं करता है या गतिविधियों का उपभोग नहीं करता है।
हम समझते हैं कि इकाई परीक्षण एक विधि है जिसके द्वारा स्रोत कोड की व्यक्तिगत इकाइयों को यह निर्धारित करने के लिए परीक्षण किया जा सकता है कि वे उपयोग के लिए फिट हैं या नहीं। जावा प्रोग्रामर परीक्षण मामलों को लिखने के लिए जूनिट फ्रेमवर्क का उपयोग कर सकते हैं। इसी तरह, MuleSoft में MUnit नाम की एक रूपरेखा भी है, जिससे हमें अपने API और एकीकरण के लिए स्वचालित परीक्षण मामले लिखने की अनुमति मिलती है। यह निरंतर एकीकरण / परिनियोजन वातावरण के लिए एकदम सही है। MUnit ढांचे का सबसे बड़ा लाभ यह है कि हम इसे Maven और Surefire के साथ एकीकृत कर सकते हैं।
MUnit की विशेषताएं
Mule MUnit परीक्षण ढांचे की कुछ बहुत ही उपयोगी विशेषताएं निम्नलिखित हैं -
MUnit फ्रेमवर्क में, हम Mule कोड के साथ-साथ Java कोड का उपयोग करके अपना Mule टेस्ट बना सकते हैं।
हम अपने Mule apps और API को डिजाइन और टेस्ट कर सकते हैं, या तो ग्राफिक या XML में, Anypoint Studio के भीतर।
MUnit हमें आसानी से मौजूदा CI / CD प्रक्रिया में परीक्षण को एकीकृत करने की अनुमति देता है।
यह ऑटो-जनरेट किए गए परीक्षण और कवरेज रिपोर्ट प्रदान करता है; इसलिए मैनुअल काम कम से कम है।
हम CI प्रक्रिया के माध्यम से अधिक पोर्टेबल परीक्षण करने के लिए स्थानीय DB / FTP / मेल सर्वर का उपयोग कर सकते हैं।
यह हमें परीक्षणों को सक्षम या अक्षम करने की अनुमति देता है।
हम प्लगइन्स के साथ MUnit ढांचे का विस्तार भी कर सकते हैं।
यह हमें संदेश प्रोसेसर कॉल को सत्यापित करने की अनुमति देता है।
MUnit टेस्टिंग फ्रेमवर्क की मदद से, हम एंडपॉइंट कनेक्टर्स को अक्षम करने के साथ-साथ इनबाउंड एंड पॉइंट्स को प्रवाहित कर सकते हैं।
हम खच्चर स्टैक ट्रेस के साथ त्रुटि रिपोर्ट की जांच कर सकते हैं।
Mule MUnit टेस्टिंग फ्रेमवर्क की नवीनतम रिलीज़
MUnit 2.1.4 Mule MUnit परीक्षण ढांचे की नवीनतम रिलीज़ है। इसके लिए निम्नलिखित हार्डवेयर और सॉफ्टवेयर आवश्यकताओं की आवश्यकता है -
- एमएस विंडोज 8+
- Apple Mac OS X 10.10+
- Linux
- जावा 8
- मावेन 3.3.3, 3.3.9, 3.5.4, 3.6.0
यह Mule 4.1.4 और Anypoint Studio 7.3.0 के साथ संगत है।
MUnit और Anypoint स्टूडियो
जैसा कि चर्चा की गई है, MUnit पूरी तरह से Anypoint स्टूडियो में एकीकृत है और हम अपने Mule apps और API को ग्राफिक रूप से या XML में Anypoint स्टूडियो के लिए डिज़ाइन और टेस्ट कर सकते हैं। दूसरे शब्दों में, हम निम्न करने के लिए Anypoint Studio के ग्राफिकल इंटरफ़ेस का उपयोग कर सकते हैं -
- MUnit परीक्षण बनाने और डिजाइन करने के लिए
- हमारे परीक्षण चलाने के लिए
- परीक्षा परिणामों के साथ-साथ कवरेज रिपोर्ट देखने के लिए
- परीक्षण डिबगिंग के लिए
तो, आइए हम एक-एक करके प्रत्येक कार्य पर चर्चा शुरू करें।
MUnit टेस्ट बनाना और डिजाइन करना
एक बार जब आप नई परियोजना शुरू करते हैं, तो यह स्वचालित रूप से एक नया फ़ोल्डर जोड़ देगा src/test/munitहमारी परियोजना के लिए। उदाहरण के लिए, हमने एक नई खच्चर परियोजना शुरू कीtest_munit, आप नीचे दी गई छवि में देख सकते हैं, यह हमारी परियोजना के तहत उपर्युक्त फ़ोल्डर जोड़ता है।
अब, जब आपने एक नई परियोजना शुरू की, तो Anypoint Studio में एक नया MUnit परीक्षण बनाने के दो बुनियादी तरीके हैं -
By Right-Clicking the Flow - इस पद्धति में, हमें विशिष्ट प्रवाह पर राइट-क्लिक करना होगा और ड्रॉप-डाउन मेनू से MUnit का चयन करना होगा।
By Using the Wizard- इस पद्धति में, हमें परीक्षण बनाने के लिए विज़ार्ड का उपयोग करने की आवश्यकता है। यह हमें कार्यक्षेत्र में किसी भी प्रवाह के लिए एक परीक्षण बनाने की अनुमति देता है।
हम विशिष्ट प्रवाह के लिए एक परीक्षण बनाने के लिए 'राइट-क्लिक द फ्लो' का उपयोग करने जा रहे हैं।
सबसे पहले, हमें कार्यक्षेत्र में एक प्रवाह बनाने की जरूरत है -
अब, इस प्रवाह पर राइट क्लिक करें और इस प्रवाह के लिए एक परीक्षण बनाने के लिए MUnit का चयन करें, जैसा कि नीचे दिखाया गया है -
यह XML फ़ाइल के नाम पर एक नया परीक्षण सूट बनाएगा जहाँ प्रवाह रहता है। इस मामले में,test_munit-test-suite नीचे दिखाए गए अनुसार नए टेस्ट सूट का नाम है -
उपरोक्त संदेश प्रवाह के लिए XML संपादक निम्नलिखित है -
अब, हम एक जोड़ सकते हैं MUnit संदेश प्रोसेसर को टेस्ट सूट से खच्चर पैलेट से खींचकर।
यदि आप विज़ार्ड के माध्यम से एक परीक्षण बनाना चाहते हैं तो अनुसरण करें File → New → MUnit और यह आपको निम्नलिखित MUnit परीक्षण सूट तक ले जाएगा -
परीक्षण को कॉन्फ़िगर करना
Mule 4 में, हमारे पास दो नए अनुभाग हैं MUnit तथा MUnit Tools, सामूहिक रूप से सभी MUnit संदेश प्रोसेसर होने। आप अपने MUnit परीक्षण क्षेत्र में किसी भी संदेश प्रोसेसर को खींच सकते हैं। यह नीचे स्क्रीनशॉट में दिखाया गया है -
अब, यदि आप Anypoint Studio में अपने सूट या परीक्षण के लिए कॉन्फ़िगरेशन को संपादित करना चाहते हैं, तो आपको निम्न चरणों का पालन करने की आवश्यकता है -
Step 1
के पास जाओ Package Explorer और दाईं ओर क्लिक करें .xml fileअपने सूट या परीक्षण के लिए। फिर, चयन करेंProperties।
Step 2
अब, गुण विंडो में, हमें क्लिक करने की आवश्यकता है Run/Debug Settingएस इसके बाद क्लिक करेंNew।
Step 3
अंतिम चरण में, क्लिक करें MUnit के अंतर्गत Select Configuration Type विंडो, और फिर क्लिक करें OK।
टेस्ट चल रहा है
हम एक परीक्षण सूट के साथ-साथ एक परीक्षण भी चला सकते हैं। सबसे पहले, हम देखेंगे कि टेस्ट सूट कैसे चलाना है।
टेस्ट सूट चलाना
टेस्ट सूट चलाने के लिए, Mule Canvas के खाली हिस्से पर राइट क्लिक करें, जहाँ आपका टेस्ट सूट रहता है। यह एक ड्रॉप-डाउन मेनू खोल देगा। अब, पर क्लिक करेंRun MUnit suite जैसा कि नीचे दिखाया गया है -
बाद में, हम आउटपुट को कंसोल में देख सकते हैं।
टेस्ट चल रहा है
एक विशिष्ट परीक्षण चलाने के लिए, हमें विशिष्ट परीक्षण का चयन करना होगा और उस पर राइट-क्लिक करना होगा। हमें वही ड्रॉप-डाउन मेनू मिलेगा जैसा हमें टेस्ट सूट चलाते समय मिला था। अब, पर क्लिक करेंRun MUnit Test नीचे दिखाए अनुसार विकल्प -
आउटपुट के बाद कंसोल में देखा जा सकता है।
परीक्षा परिणाम देखना और विश्लेषण करना
Anypoint स्टूडियो में MUnit परीक्षा परिणाम प्रदर्शित करता है MUnit tabबाएं हाथ की खोज फलक। आप हरे रंग में सफल परीक्षण पा सकते हैं और नीचे दिखाए गए लाल रंग में असफल परीक्षण -
हम कवरेज रिपोर्ट देखकर अपने परीक्षा परिणाम का विश्लेषण कर सकते हैं। कवरेज रिपोर्ट की मुख्य विशेषता यह है कि MUnit परीक्षणों के एक सेट द्वारा एक खच्चर आवेदन को सफलतापूर्वक निष्पादित किया गया है, इस पर एक मीट्रिक प्रदान करना है। MUnit कवरेज मूल रूप से निष्पादित MUnit संदेश प्रोसेसर की मात्रा पर आधारित है। MUnit कवरेज रिपोर्ट निम्नलिखित के लिए मीट्रिक प्रदान करती है -
- आवेदन समग्र कवरेज
- संसाधन कवरेज
- प्रवाह कवरेज
कवरेज रिपोर्ट प्राप्त करने के लिए, हमें नीचे दिखाए अनुसार MUnit टैब के अंतर्गत 'जनरेट रिपोर्ट' पर क्लिक करना होगा -
परीक्षण को डिबग करना
हम टेस्ट सूट के साथ-साथ टेस्ट में भी डेब्यू कर सकते हैं। सबसे पहले, हम देखेंगे कि टेस्ट सूट को कैसे डिबग किया जाए।
एक टेस्ट सूट डिबगिंग
टेस्ट सूट डिबग करने के लिए, Mule Canvas के खाली हिस्से पर राइट क्लिक करें जहाँ आपका टेस्ट सूट रहता है। यह एक ड्रॉप-डाउन मेनू खोल देगा। अब, पर क्लिक करेंDebug MUnit Suite जैसा कि नीचे दी गई छवि में दिखाया गया है -
फिर, हम आउटपुट को कंसोल में देख सकते हैं।
एक परीक्षण डिबगिंग
किसी विशिष्ट परीक्षण को डीबग करने के लिए, हमें विशिष्ट परीक्षण का चयन करना होगा और उस पर राइट-क्लिक करना होगा। हमें वही ड्रॉप-डाउन मेनू मिलेगा जैसा हमें टेस्ट सूट को डिबग करने के दौरान मिला था। अब, पर क्लिक करेंDebug MUnit Testविकल्प। इसे नीचे स्क्रीन शॉट में दिखाया गया है।