Apache Camel - Sekilas
Unta adalah kotak hitam yang menerima pesan dari beberapa titik akhir dan mengirimkannya ke titik lain. Di dalam kotak hitam, pesan dapat diproses atau diarahkan ulang.
Jadi mengapa harus kerangka untuk ini? Dalam situasi praktis seperti yang terlihat dalam studi kasus pendahuluan, mungkin ada banyak pengirim dan banyak penerima yang masing-masing mengikuti protokolnya sendiri seperti ftp, http dan jms. Sistem mungkin memerlukan banyak aturan kompleks seperti pesan dari pengirim A harus dikirim hanya ke B & C. Dalam situasi ini, Anda mungkin harus menerjemahkan pesan ke format lain yang diharapkan penerima. Terjemahan ini mungkin tunduk pada kondisi tertentu berdasarkan isi pesan. Jadi pada dasarnya Anda mungkin perlu menerjemahkan antar protokol, merekatkan komponen bersama, menentukan aturan perutean, dan menyediakan pemfilteran berdasarkan konten pesan. Ini diilustrasikan pada gambar berikut -
Untuk memenuhi persyaratan di atas dan merancang arsitektur perangkat lunak yang tepat untuk banyak situasi seperti itu, Pola Integrasi Perusahaan ( EIP ) didokumentasikan oleh Gregor Hohpe dan Bobby Woolf pada tahun 2003. Apache Camel menyediakan penerapan pola-pola ini dan tujuan dari tutorial ini adalah untuk mengajar Anda bagaimana menggunakan Unta dalam situasi seperti yang dijelaskan dalam pendahuluan.
Apache Camel adalah kerangka kerja sumber terbuka. Ini adalah middleware berorientasi pesan yang menyediakan perutean berbasis aturan dan mesin mediasi. Anda dapat menetapkan aturan seperti jika ini adalah pesanan "susu" yang mengarahkannya ke vendor susu dan jika itu adalah pesanan "minyak", arahkan ke vendor minyak, dan seterusnya. Dengan menggunakan Camel, Anda akan dapat menerapkan aturan ini dan melakukan perutean dalam kode Java yang sudah dikenal. Ini berarti Anda dapat menggunakan Java IDE yang sudah Anda kenal untuk menentukan aturan ini dalam lingkungan yang aman bagi tipe. Kami tidak perlu menggunakan file konfigurasi XML, yang biasanya cenderung besar. Camel mendukung konfigurasi XML melalui kerangka kerja Spring, jika Anda lebih suka menggunakan XML untuk mengonfigurasi aturan. Anda bahkan dapat menggunakan file Blueprint XML Configuration dan bahkan Scala DSL, jika Anda pecinta Scala. Ini juga berarti Anda dapat menggunakan Java favorit Anda, Scala IDE atau bahkan editor XML sederhana untuk mengonfigurasi aturan.
Input ke mesin ini dapat berupa file teks yang dipisahkan koma, POJO (Objek Java Lama Biasa), XML adalah salah satu dari beberapa format lain yang didukung oleh Camel. Demikian pula, output mesin dapat diarahkan ke file, ke antrian pesan atau bahkan layar monitor Anda agar Anda dapat melihat pesanan yang dikirim ke masing-masing vendor. Ini disebut titik akhir dan Unta mendukung pola EIP Titik Akhir Pesan . Titik akhir Unta dibahas nanti di bab Titik Akhir.
Camel biasanya digunakan dengan Apache ServiceMix , Apache ActiveMQ, dan Apache CXF untuk mengimplementasikan arsitektur berorientasi layanan.