อูฐ 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>
เมื่อได้เห็นวิธีสร้างเส้นทางแล้วตอนนี้เราจะเห็นเทคนิคต่างๆในการสร้างจุดสิ้นสุด