Apache ऊंट - CamelContext

CamelContext कैमल को अन्य सभी सेवाओं तक पहुंच प्रदान करता है जैसा कि निम्नलिखित आंकड़े में दिखाया गया है -

आइए हम विभिन्न सेवाओं को देखें। Registryडिफ़ॉल्ट रूप से मॉड्यूल एक JNDI रजिस्ट्री है, जो आपके एप्लिकेशन का उपयोग करने वाले विभिन्न जावबीन का नाम रखती है। यदि आप स्प्रिंग के साथ कैमल का उपयोग करते हैं, तो यह स्प्रिंग होगाApplicationContext। यदि आप OSGI कंटेनर में कैमल का उपयोग करते हैं, तो यह होगाOSGI registryType convertersजैसा कि नाम से पता चलता है कि विभिन्न लोड किए गए प्रकार कन्वर्टर्स हैं, जो आपके इनपुट को एक प्रारूप से दूसरे प्रारूप में परिवर्तित करते हैं। आप अंतर्निहित प्रकार के कन्वर्टर्स का उपयोग कर सकते हैं या रूपांतरण का अपना तंत्र प्रदान कर सकते हैं। Componentsमॉड्यूल में आपके एप्लिकेशन द्वारा उपयोग किए जाने वाले घटक होते हैं। घटकों को ऑटो खोज द्वारा लोड किया जाता हैclasspathआप निर्दिष्ट करें। OSGI कंटेनर के मामले में, जब भी कोई नया बंडल सक्रिय होता है, तो ये लोड होते हैं। हम पहले ही चर्चा कर चुके हैंEndpoints तथा Routesपिछले अध्यायों में। Data formats मॉड्यूल में लोड किए गए डेटा प्रारूप होते हैं और अंत में Languages मॉड्यूल भरी हुई भाषाओं का प्रतिनिधित्व करता है।

यहाँ कोड स्निपेट आपको एक झलक देगा कि कैसे CamelContext एक ऊंट आवेदन में बनाया गया है -

CamelContext context = new DefaultCamelContext();
try {
   context.addRoutes(new RouteBuilder() {
      // Configure filters and routes
   }
}
);

DefaultCamelContext वर्ग एक ठोस कार्यान्वयन प्रदान करता है CamelContext। मेंaddRoutes विधि, हम एक अनाम उदाहरण बनाते हैं RouteBuilder। आप कई बना सकते हैंRouteBuilderएक से अधिक रूटिंग को परिभाषित करने के लिए उदाहरण। एक ही संदर्भ में प्रत्येक मार्ग के पास एक विशिष्ट आईडी होनी चाहिए। रूट पर गतिशील रूप से रूट जोड़े जा सकते हैं। पहले से परिभाषित आईडी के साथ एक मार्ग पुराने मार्ग को बदल देगा।

अंदर क्या जाता है RouteBuilder उदाहरण अगले वर्णित है।

मार्गों

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

यहाँ एक विशिष्ट उदाहरण है कि मार्ग कैसे बनाया जाता है -

context.addRoutes(new RouteBuilder() {
   @Override
   public void configure() throws Exception {
      from("direct:DistributeOrderDSL")
      .to("stream:out");
   }
}

हम की कॉन्फ़िगर विधि को ओवरराइड करते हैं RouteBuilderइसमें हमारी रूटिंग और फ़िल्टरिंग प्रणाली को क्लास करें और लागू करें। वर्तमान मामले में, हम समापन बिंदु से प्राप्त इनपुट को पुनर्निर्देशित करते हैंDistributeOrderDSL कंसोल के लिए, जो समापन बिंदु द्वारा निर्दिष्ट किया गया है stream:out

भाषा विकल्प

आप विभिन्न भाषाओं में मार्ग बना सकते हैं। यहाँ कुछ उदाहरण दिए गए हैं कि एक ही मार्ग को तीन अलग-अलग भाषाओं में कैसे परिभाषित किया जाता है -

जावा डीएसएल

from ("file:/order").to("jms:orderQueue");

स्प्रिंग डीएसएल

<route>
   <from uri = "file:/order"/>
   <to uri = "jms:orderQueue"/>
</route>

स्काला डी.एस.एल.

from "file:/order" -> "jms:orderQueue"

फिल्टर

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

from("direct:DistributeOrderDSL")
   .split(xpath("//order[@product = 'soaps']/items"))
      .to("stream:out");

उदाहरण में, हमने उपयोग किया है xpathछानने के लिए विधेय। यदि आप फ़िल्टर करने के लिए जावा वर्ग का उपयोग करना पसंद करते हैं, तो निम्न कोड का उपयोग करें -

from("direct:DistributeOrderDSL")
   .filter()
      .method(new Order(),"filter")
         .to("stream:out");

Order अपने स्वयं के फ़िल्टरिंग तंत्र के साथ आपका कस्टम जावा वर्ग है।

आप यहाँ के रूप में एक ही मार्ग में कई विधेयकों को जोड़ सकते हैं -

from("direct:DistributeOrderDSL")
   .choice()
      .when(header("order").isEqualTo("oil"))
         .to("direct:oil")
      .when(header("order").isEqualTo("milk"))
         .to("direct:milk")
      .otherwise()
         .to("direct:d");

तो अब सभी "तेल" आदेश तेल विक्रेता के पास जाएंगे, "दूध" के आदेश दूध विक्रेता और बाकी के आम पूल में जाएंगे।

कस्टम प्रोसेसर

आप कस्टम प्रोसेसिंग का भी उपयोग कर सकते हैं। नीचे दिया गया उदाहरण कस्टम प्रोसेसर बनाता है जिसे कहा जाता हैmyCustomProcessor और मार्ग बिल्डर में इसका उपयोग करता है।

Processor myCustomProcessor = new Processor() {
   public void process(Exchange exchange) {
      // implement your custom processing
   }
};
RouteBuilder builder = new RouteBuilder() {
   public void configure() {
      from("direct:DistributeOrderDSL")
      .process(myProcessor);
   }
};

आप अपनी मध्यस्थता और रूटिंग पर बेहतर नियंत्रण पाने के लिए पसंद और फ़िल्टरिंग के साथ कस्टम प्रोसेसर का उपयोग कर सकते हैं -

from("direct:DistributeOrderDSL")
   .filter(header("order").isEqualTo("milk"))
      .process(myProcessor);

XML का उपयोग करना

यदि आप इसे पसंद करते हैं, तो मार्गों को बल्कियर एक्सएमएल में परिभाषित किया जा सकता है। निम्न XML स्निपेट दिखाता है कि स्प्रिंग XML के माध्यम से कुछ फ़िल्टरिंग के साथ मार्ग कैसे बनाया जाए -

<camelContext xmlns = "http://camel.apache.org/schema/spring">
   <route>
      <from uri = "direct:DistributeOrderXML"/>
      <log message = "Split by Distribute Order"/>
      <split>
         <xpath>//order[@product = 'Oil']/items</xpath>
         <to uri = "file:src/main/resources/order/"/>
         <to uri = "stream:out"/>
      </split>
   </route>
</camelContext>

यह देखते हुए कि मार्ग कैसे बनाए जाते हैं, अब हम एंडपॉइंट बनाने की विभिन्न तकनीकों को देखेंगे।