MuleSoft - कोर घटक और कॉन्फ़िगरेशन
खच्चर की सबसे महत्वपूर्ण क्षमताओं में से एक यह है कि यह घटकों के साथ रूटिंग, ट्रांसफॉर्मिंग और प्रोसेसिंग कर सकता है, क्योंकि विभिन्न तत्वों को मिलाने वाले खच्चर एप्लिकेशन की कॉन्फ़िगरेशन फ़ाइल आकार में बहुत बड़ी है।
मूले द्वारा प्रदान किए गए विन्यास पैटर्न के प्रकार निम्नलिखित हैं -
- सरल सेवा पैटर्न
- 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 स्कीमा
- एक्सेल कॉलम नाम और प्रकार
- निश्चित चौड़ाई कॉलम नाम और प्रकार