Apache Camel - CamelContext
CamelContext menyediakan akses ke semua layanan lain di Camel seperti yang ditunjukkan pada gambar berikut -
Mari kita lihat berbagai layanan. ItuRegistrymodul secara default adalah registri JNDI, yang menyimpan nama berbagai Javabeans yang digunakan aplikasi Anda. Jika Anda menggunakan Unta dengan Musim Semi, ini akan menjadi Musim SemiApplicationContext. Jika Anda menggunakan Camel dalam wadah OSGI, ini akan menjadiOSGI registry. ItuType convertersseperti namanya berisi berbagai jenis konverter yang dimuat, yang mengubah masukan Anda dari satu format ke format lainnya. Anda dapat menggunakan konverter tipe built-in atau menyediakan mekanisme konversi Anda sendiri. ItuComponentsmodul berisi komponen yang digunakan oleh aplikasi Anda. Komponen dimuat oleh penemuan otomatis diclasspathyang Anda tentukan. Dalam kasus wadah OSGI, ini dimuat setiap kali bundel baru diaktifkan. Kami telah membahasEndpoints dan Routesdi bab sebelumnya. ItuData formats modul berisi format data yang dimuat dan terakhir Languages modul mewakili bahasa yang dimuat.
Cuplikan kode di sini akan memberi Anda gambaran sekilas tentang bagaimana a CamelContext dibuat dalam aplikasi Unta -
CamelContext context = new DefaultCamelContext();
try {
context.addRoutes(new RouteBuilder() {
// Configure filters and routes
}
}
);
Itu DefaultCamelContext kelas menyediakan implementasi konkret CamelContext. DiaddRoutes metode, kami membuat contoh anonim RouteBuilder. Anda dapat membuat lebih dari satuRouteBuildercontoh untuk menentukan lebih dari satu perutean. Setiap rute dalam konteks yang sama harus memiliki ID unik. Rute dapat ditambahkan secara dinamis pada saat runtime. Rute dengan ID yang sama dengan yang ditentukan sebelumnya akan menggantikan rute yang lebih lama.
Apa yang ada di dalam RouteBuilder Misalnya dijelaskan selanjutnya.
Rute
Router menentukan aturan untuk memindahkan pesan from ke a tolokasi. Kau gunakanRouteBuilderuntuk menentukan rute di Java DSL. Anda membuat rute dengan memperluas built-inRouteBuilderkelas. Rute dimulai dengan afromtitik akhir dan selesai di satu atau lebih ke titik akhir. Di antara keduanya, Anda menerapkan logika pemrosesan. Anda dapat mengonfigurasi sejumlah rute dalam satuconfigure metode.
Berikut adalah contoh umum bagaimana rute dibuat -
context.addRoutes(new RouteBuilder() {
@Override
public void configure() throws Exception {
from("direct:DistributeOrderDSL")
.to("stream:out");
}
}
Kami mengganti metode konfigurasi RouteBuilderkelas dan menerapkan mekanisme perutean dan pemfilteran kami di dalamnya. Dalam kasus saat ini, kami mengalihkan input yang diterima dari EndpointDistributeOrderDSL ke konsol, yang ditentukan oleh Endpoint stream:out.
Pilihan Bahasa
Anda dapat membuat rute dalam berbagai bahasa. Berikut adalah beberapa contoh bagaimana rute yang sama didefinisikan dalam tiga bahasa berbeda -
Java DSL
from ("file:/order").to("jms:orderQueue");
Musim semi DSL
<route>
<from uri = "file:/order"/>
<to uri = "jms:orderQueue"/>
</route>
Scala DSL
from "file:/order" -> "jms:orderQueue"
Filter
Anda menggunakan filter untuk memilih bagian dari konten masukan. Untuk menyiapkan filter, Anda menggunakan implementasi Predicate sembarang . Masukan yang difilter kemudian dikirim ke Endpoint tujuan yang Anda inginkan. Dalam contoh ini, kami menyaring semua pesanan sabun agar dapat dikirim secara kolektif ke pemasok sabun.
from("direct:DistributeOrderDSL")
.split(xpath("//order[@product = 'soaps']/items"))
.to("stream:out");
Dalam contoh, kami telah menggunakan xpathpredikat untuk penyaringan. Jika Anda lebih suka menggunakan kelas Java untuk pemfilteran, gunakan kode berikut -
from("direct:DistributeOrderDSL")
.filter()
.method(new Order(),"filter")
.to("stream:out");
Itu Order adalah kelas Java khusus Anda dengan mekanisme pemfilteran Anda sendiri.
Anda dapat menggabungkan beberapa predikat dalam satu perutean seperti di sini -
from("direct:DistributeOrderDSL")
.choice()
.when(header("order").isEqualTo("oil"))
.to("direct:oil")
.when(header("order").isEqualTo("milk"))
.to("direct:milk")
.otherwise()
.to("direct:d");
Jadi sekarang semua pesanan "minyak" akan pergi ke penjual minyak, pesanan "susu" akan pergi ke penjual susu dan sisanya ke kolam umum.
Prosesor Kustom
Anda juga dapat menggunakan pemrosesan kustom. Contoh di bawah ini membuat prosesor khusus yang disebutmyCustomProcessor dan menggunakannya di pembuat rute.
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);
}
};
Anda dapat menggunakan prosesor kustom bersama dengan pilihan dan pemfilteran untuk mendapatkan kontrol yang lebih baik pada mediasi dan perutean Anda -
from("direct:DistributeOrderDSL")
.filter(header("order").isEqualTo("milk"))
.process(myProcessor);
Menggunakan XML
Rute dapat ditentukan dalam XML yang lebih besar, jika Anda lebih suka. Potongan XML berikut menunjukkan cara membuat rute bersama dengan beberapa pemfilteran melalui 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>
Setelah melihat bagaimana rute dibangun, sekarang kita akan melihat berbagai teknik pembuatan Titik Akhir.