อูฐ Apache - CamelContext

CamelContext ให้การเข้าถึงบริการอื่น ๆ ทั้งหมดใน Camel ดังแสดงในรูปต่อไปนี้ -

ให้เราดูบริการต่างๆ Registryโมดูลโดยค่าเริ่มต้นคือรีจิสตรี JNDI ซึ่งเก็บชื่อ Javabeans ต่างๆที่แอปพลิเคชันของคุณใช้ ถ้าคุณใช้ Camel กับ Spring นี่จะเป็น SpringApplicationContext. หากคุณใช้ Camel ในคอนเทนเนอร์ OSGI สิ่งนี้จะเป็นOSGI registry. Type convertersตามชื่อที่แนะนำมีตัวแปลงประเภทต่างๆที่โหลดซึ่งจะแปลงอินพุตของคุณจากรูปแบบหนึ่งไปเป็นอีกรูปแบบหนึ่ง คุณสามารถใช้ตัวแปลงประเภทที่มีอยู่แล้วภายในหรือระบุกลไกการแปลงของคุณเอง Componentsโมดูลประกอบด้วยส่วนประกอบที่แอปพลิเคชันของคุณใช้ ส่วนประกอบถูกโหลดโดยการค้นหาอัตโนมัติในไฟล์classpathที่คุณระบุ ในกรณีของคอนเทนเนอร์ OSGI สิ่งเหล่านี้จะถูกโหลดทุกครั้งที่เปิดใช้งานบันเดิลใหม่ เราได้หารือเกี่ยวกับไฟล์Endpoints และ Routesในบทก่อนหน้า Data formats โมดูลมีรูปแบบข้อมูลที่โหลดและสุดท้ายคือ Languages โมดูลแสดงถึงภาษาที่โหลด

ข้อมูลโค้ดที่นี่จะทำให้คุณเห็นว่าไฟล์ CamelContext ถูกสร้างขึ้นในแอปพลิเคชัน Camel -

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

DefaultCamelContext คลาสให้การนำไปใช้อย่างเป็นรูปธรรม CamelContext. ในaddRoutes เราสร้างอินสแตนซ์ที่ไม่ระบุตัวตนของ RouteBuilder. คุณสามารถสร้างหลาย ๆRouteBuilderอินสแตนซ์เพื่อกำหนดการกำหนดเส้นทางมากกว่าหนึ่งรายการ แต่ละเส้นทางในบริบทเดียวกันต้องมี ID ที่ไม่ซ้ำกัน สามารถเพิ่มเส้นทางได้แบบไดนามิกที่รันไทม์ เส้นทางที่มี ID เหมือนกับที่กำหนดไว้ก่อนหน้านี้จะแทนที่เส้นทางเก่า

สิ่งที่อยู่ภายในไฟล์ RouteBuilder อินสแตนซ์จะอธิบายต่อไป

เส้นทาง

เราเตอร์กำหนดกฎสำหรับการย้ายข้อความ from ถึงก toสถานที่. คุณใช้RouteBuilderเพื่อกำหนดเส้นทางใน Java DSL คุณสร้างเส้นทางโดยการขยายในตัวRouteBuilderชั้นเรียน เส้นทางเริ่มต้นด้วยfromจุดสิ้นสุดและสิ้นสุดที่จุดสิ้นสุดหนึ่งจุดหรือมากกว่า ในระหว่างทั้งสองคุณใช้ตรรกะการประมวลผล คุณสามารถกำหนดเส้นทางจำนวนเท่าใดก็ได้ภายในหนึ่งเดียวconfigure วิธี.

นี่คือตัวอย่างทั่วไปของการสร้างเส้นทาง -

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

เราลบล้างวิธีกำหนดค่าของ RouteBuilderคลาสและใช้กลไกการกำหนดเส้นทางและการกรองของเราในนั้น ในกรณีปัจจุบันเราเปลี่ยนเส้นทางอินพุตที่ได้รับจากปลายทางDistributeOrderDSL ไปยังคอนโซลซึ่งระบุโดย Endpoint stream:out.

ตัวเลือกภาษา

คุณสามารถสร้างเส้นทางในภาษาต่างๆ นี่คือตัวอย่างบางส่วนของการกำหนดเส้นทางเดียวกันในสามภาษาที่แตกต่างกัน -

Java DSL

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

สปริง DSL

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

Scala DSL

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

ฟิลเตอร์

คุณใช้ตัวกรองเพื่อเลือกส่วนหนึ่งของเนื้อหาอินพุต การตั้งค่าตัวกรองที่คุณใช้ใด ๆ โดยพลการสรุปการดำเนินงาน จากนั้นข้อมูลที่กรองแล้วจะถูกส่งไปยังปลายทางปลายทางที่คุณต้องการ ในตัวอย่างนี้เรากรองคำสั่งซื้อทั้งหมดสำหรับสบู่เพื่อให้สามารถส่งรวมกันไปยังซัพพลายเออร์สบู่ได้

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

ในตัวอย่างเราได้ใช้ xpathเพรดิเคตสำหรับการกรอง หากคุณต้องการใช้คลาส Java ในการกรองให้ใช้รหัสต่อไปนี้ -

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

Order เป็นคลาส Java ที่คุณกำหนดเองพร้อมกลไกการกรองของคุณเอง

คุณสามารถรวมเพรดิเคตหลายตัวในการกำหนดเส้นทางเดียวได้ที่นี่ -

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 ต่อไปนี้แสดงวิธีสร้างเส้นทางพร้อมกับการกรองผ่าน Spring 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>

เมื่อได้เห็นวิธีสร้างเส้นทางแล้วตอนนี้เราจะเห็นเทคนิคต่างๆในการสร้างจุดสิ้นสุด