BPEL - Panduan Cepat

SOA atau Arsitektur Berorientasi Layanan adalah pendekatan arsitektural, yang memanfaatkan teknologi untuk menyajikan proses bisnis sebagai layanan yang dapat digunakan kembali.

  • Ini difokuskan pada bisnis dan memungkinkan transformasi proses ke tingkat integrasi, visualisasi, pemantauan, dan pengoptimalan baru.

  • Ini bukan teknologi, ini adalah konsep dan strategi untuk menggunakan teknologi untuk membangun solusi otomasi bisnis.

Sekarang kita akan melihat apa itu BPEL dan bagaimana hal itu membantu dalam SOA.

Apa itu BPEL?

Bahasa Rekayasa Proses Bisnis adalah teknologi yang digunakan untuk membangun program dalam arsitektur SOA.

Menambahkan Komponen Layanan Proses BPEL

Ikuti langkah-langkah ini untuk menambahkan Komponen Layanan Proses BPEL -

  • Dari Application Navigator, pilih File> New> Applications> SOA Application.

  • Ini memulai wizard Buat Aplikasi SOA.

  • Dalam dialog Nama Aplikasi, masukkan nama aplikasi di bidang Nama Aplikasi.

  • Di bidang Direktori, masukkan jalur direktori untuk membuat aplikasi dan proyek komposit SOA.

  • Klik Next.

  • Dalam dialog Nama Proyek, masukkan nama di bidang Nama Proyek.

  • Klik Next.

  • Dalam dialog Project SOA Settings, pilih Composite with the BPEL Process.

  • Klik Selesai.

File di BPEL Composite

Komposit BPEL berisi file-file berikut -

  • composite.xml - File ini menjelaskan keseluruhan gabungan layanan, komponen layanan, referensi, dan kabel.

  • .bpel - File ini berisi serangkaian aktivitas yang ditambahkan ke proses.

  • .componentType - File ini menjelaskan layanan dan referensi untuk komponen layanan proses BPEL.

  • .wsdl - File ini mendefinisikan pesan input dan output untuk aliran proses BPEL ini, antarmuka dan operasi klien yang didukung, dan fitur lainnya.

Konsep yang digunakan dalam proses BPL

Pada bagian ini, kita akan mempelajari berbagai konsep yang terlibat dalam proses BPL.

Orkestrasi

    Biasanya digunakan dalam proses bisnis pribadi.
  • Proses sentral (yang dapat berupa layanan Web lain) mengambil kendali atas layanan Web yang terlibat.

  • Mengoordinasikan pelaksanaan berbagai operasi di layanan web yang terlibat dalam operasi tersebut.

  • Layanan Web yang terlibat tidak "tahu" (dan tidak perlu tahu) bahwa mereka terlibat dalam proses komposisi dan bahwa mereka mengambil bagian dalam proses bisnis tingkat yang lebih tinggi.
  • Hanya koordinator pusat orkestrasi yang mengetahui tujuan ini, sehingga orkestrasi terpusat dengan definisi operasi yang eksplisit dan urutan pemanggilan layanan Web.

Koreografi

  • Tidak bergantung pada koordinator pusat.

  • Setiap layanan Web yang terlibat dalam koreografi tahu persis kapan harus menjalankan operasinya dan dengan siapa berinteraksi.

  • Setiap layanan Web yang terlibat dalam koreografi tahu persis kapan harus menjalankan operasinya dan dengan siapa berinteraksi.

  • Semua peserta dalam koreografi perlu mengetahui proses bisnis, operasi yang akan dijalankan, pesan untuk dipertukarkan, dan waktu pertukaran pesan.

Dalam bab ini, kita akan mempelajari tentang berbagai aktivitas yang membentuk blok bangunan. Blok bangunan dari komponen layanan proses BPEL.

Oracle BPEL Designer menyertakan sekumpulan aktivitas yang Anda seret ke dalam komponen layanan proses BPEL dan klik dua kali aktivitas untuk menentukan atribut dan nilai propertinya.

Tetapkan Aktivitas

 Aktivitas assign memungkinkan untuk memanipulasi data, seperti menyalin konten dari satu variabel ke variabel lainnya.

Ajukan Aktivitas

 Aktivitas pemanggilan memungkinkan Anda memanggil layanan (diidentifikasi oleh tautan mitranya) dan menentukan operasi untuk dijalankan oleh layanan ini.

Terima Aktivitas

  Aktivitas terima menunggu pesan respons panggilan balik asinkron dari layanan.

Mari kita pelajari lebih lanjut tentang aktivitas Memanggil di bagian selanjutnya.

Ajukan Aktivitas

Aktivitas pemanggilan memungkinkan untuk menentukan operasi yang akan dipanggil untuk layanan (diidentifikasi oleh tautan mitranya). Operasi bisa satu arah atau permintaan-respon pada port yang disediakan oleh layanan. Variabel dapat dibuat secara otomatis dalam aktivitas pemanggilan. Aktivitas pemanggilan memanggil layanan sinkron atau memulai layanan web asinkron.

Aktivitas pemanggilan membuka port dalam proses untuk mengirim dan menerima data. Port ini selanjutnya dapat digunakan untuk mengirimkan data yang diperlukan dan menerima tanggapan. Untuk panggilan balik sinkron, hanya satu port yang diperlukan untuk fungsi kirim dan terima.

Tautan Mitra didefinisikan sebagai pertukaran komunikasi antara semua pihak yang berinteraksi dengan Proses BPEL.

Mereka adalah referensi untuk implementasi aktual, yang melaluinya proses BPEL berinteraksi dengan dunia luar.

Tautan Mitra yang Diminta

Ini adalah tautan ke layanan yang dipanggil oleh proses BPEL.

Tautan Mitra Klien

Ini adalah tautan ke layanan yang dapat menjalankan proses BPEL.

Properti Tautan Mitra

Editor Properti Tautan Mitra memungkinkan Anda membuat tautan mitra untuk proses BPEL Anda. Dengan Editor Properti Tautan Mitra, Anda dapat menentukan hal berikut -

  • Name - Menentukan nama elemen Invoke.

  • WSDL File - Menunjukkan file WSDL yang terkait dengan Tautan Mitra.

  • Partner Link Type - Menunjukkan jenis Tautan Mitra yang ditentukan dalam WSDL.

  • My Role - Menunjukkan peran proses bisnis itu sendiri.

  • Partner Pole - Menunjukkan peran mitra.

  • Documentation - Diakses di jendela Properties.

Tautan Mitra ditentukan dalam file .bpel.

BPEL dapat berinteraksi dengan layanan melalui tiga cara berikut -

  • Layanan yang meminta proses BPEL
  • Layanan yang dijalankan oleh proses BPEL
  • Layanan yang bertindak dua arah

Pada bab ini, kita akan mempelajari cara membuat tautan mitra.

Ikuti langkah-langkah yang ditunjukkan di bawah ini untuk membuat tautan mitra -

  • Di SOA Composite Editor, klik dua kali komponen layanan proses BPEL.

  • Setelah mengklik komponen layanan, Oracle BPEL Designer akan ditampilkan.

  • Di Palet Komponen, perluas Layanan BPEL.

  • Tarik Tautan Mitra ke swimlane Tautan Mitra yang sesuai.

  • Lengkapi bidang untuk dialog ini seperti yang disebutkan di atas di Properti Tautan Mitra.

Adaptor memungkinkan untuk mengintegrasikan komponen layanan proses BPEL dengan akses ke sistem file, server FTP, tabel database, antrian database, soket, Java Message Services (JMS), MQ, dan Oracle E-Business Suite. Wisaya ini memungkinkan untuk mengkonfigurasi jenis adaptor yang ditunjukkan pada gambar di bawah ini untuk digunakan dengan komponen layanan proses BPEL -

Jenis Adaptor

Gambar berikut menunjukkan jenis adaptor yang berbeda -

Antrian Lanjutan (AQ)

Untuk interaksi dengan antrian. AQ menyediakan mekanisme yang fleksibel untuk komunikasi dua arah dan asinkron antara aplikasi yang berpartisipasi.

Oracle Business Activity Monitoring (BAM)

Untuk mempublikasikan data ke objek data di Oracle BAM Server.

Database

Untuk interaksi dengan database Oracle dan non-Oracle melalui JDBC dan Oracle Business Intelligence (yang merupakan tipe sumber data khusus).

FTP dan File

Untuk pertukaran file (baca dan tulis) pada sistem file lokal dan sistem file jarak jauh (melalui penggunaan protokol transfer file (FTP)).

Layanan Pesan Java (JMS)

Untuk interaksi dengan JMS. Arsitektur JMS menggunakan satu antarmuka klien ke banyak arsitektur server perpesanan.

Antrian Pesan (MQ)

Untuk pertukaran pesan dengan sistem antrian WebSphere MQ.

Aplikasi Oracle

Untuk interaksi dengan kumpulan aplikasi bisnis terintegrasi Oracle Application.

Oracle B2B

Untuk menelusuri metadata B2B di repositori layanan metadata (MDS) dan memilih definisi dokumen.

Soket

Untuk pemodelan protokol standar atau tidak standar untuk komunikasi melalui soket TCP / IP.

Nama Layanan Adaptor

Jendela Service Name meminta untuk memasukkan nama, ketika jenis adaptor dipilih dari palet. Untuk contoh ini,File Adapterterpilih. Saat wizard selesai, file WSDL dengan nama layanan ini muncul di Application Navigator untuk komponen layanan proses BPEL (untuk contoh ini, dinamaiReadFile.wsdl). Nama layanan dalam proyek harus unik. File konfigurasi ini menyertakan pengaturan konfigurasi adaptor yang ditentukan dengan wizard ini. File konfigurasi lain (seperti file header dan file khusus untuk adaptor) juga dibuat. File-file ini ditampilkan di Application Navigator.

Monitor proses BPEL di Oracle BPEL Designer dapat dikonfigurasi dengan memilih Monitor di bagian atas Oracle BPEL Designer.

Pada tahap ini, Adaptor BAM Oracle perlu dikonfigurasi.

Proses BPEL Klien mengirimkan pesan ke Proses BPEL Layanan dan Proses BPEL Layanan tidak perlu membalas seperti yang ditunjukkan pada gambar di bawah -

  • Proses BPEL Klien membutuhkan tautan mitra yang valid dan aktivitas pemanggilan.

  • Proses BPEL Layanan membutuhkan aktivitas menerima.

  • Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi. File WSDL seperti yang ditunjukkan di bawah ini.

<wsdl:portType name = "BPELProcess">
   <wsdl:operation name = "process">
      <wsdl:input message = "client:BPELProcessRequestMessage" />
      <wsdl:output message = "client:BPELProcessResponseMessage"/>
   </wsdl:operation>
</wsdl:portType>

Proses BPEL Klien mengirimkan permintaan ke Proses BPEL Layanan (d1 pada gambar di bawah), dan menerima balasan langsung (d2 pada gambar di bawah). Misalnya, pengguna meminta langganan formulir aplikasi online untuk masuk ke perguruan tinggi dan segera menerima konfirmasi email bahwa permintaan mereka telah diterima.

  • Proses BPEL Klien membutuhkan aktivitas pemanggilan. Porta di sisi klien mengirimkan permintaan dan menerima balasan.

  • Proses BPEL Layanan memerlukan aktivitas penerimaan untuk menerima permintaan masuk, dan aktivitas balasan untuk mengembalikan informasi yang diminta atau pesan kesalahan (kesalahan; f1 pada gambar di bawah) yang ditentukan dalam WSDL.

  • Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi. File WSDL seperti yang ditunjukkan di bawah ini.

WSDL File

<wsdl:portType name = "BPELProcess">
   <wsdl:operation name = "process">
      <wsdl:input message = "client:BPELProcessRequestMessage" />
      <wsdl:output message = "client:BPELProcessResponseMessage"/>
   </wsdl:operation>
</wsdl:portType>

Proses BPEL Klien mengirimkan permintaan ke Proses BPEL Layanan (d1 pada gambar yang diberikan di bawah), dan menunggu sampai layanan membalas (d2 pada gambar yang diberikan di bawah).

Misalnya, seorang pengguna meminta berlangganan formulir aplikasi online untuk masuk ke perguruan tinggi dan permintaan tersebut tidak dapat dikonfirmasi kecuali jika diterima di kantor penerimaan.

  • Proses BPEL Klien membutuhkan aktivitas pemanggilan untuk mengirim permintaan dan aktivitas penerimaan untuk menerima balasan.

  • Proses BPEL Layanan memerlukan aktivitas menerima untuk menerima permintaan masuk dan aktivitas pemanggilan untuk mengembalikan informasi yang diminta atau kesalahan.

    Note - Perbedaan antara merespons dari proses BPEL sinkron dan asinkron adalah bahwa layanan sinkron menggunakan aktivitas balasan untuk merespons klien dan layanan asinkron menggunakan aktivitas pemanggilan.

  • Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi. File WSDL seperti yang ditunjukkan di bawah ini.

WSDL File

<wsdl:portType name = "BPELProcess">
   <wsdl:operation name = "process">
      <wsdl:input message = "client:BPELProcessRequestMessage"/>
   </wsdl:operation>
</wsdl:portType>

<wsdl:portType name = "BPELProcessCallback">
   <wsdl:operation name = "processResponse">
      <wsdl:input message = "client:BPELProcessResponseMessage"/>
   </wsdl:operation>
</wsdl:portType>

Proses BPEL Klien mengirimkan permintaan ke Proses BPEL Layanan (d1 pada gambar di bawah), dan menunggu hingga layanan membalas atau sampai batas waktu tertentu tercapai, mana saja yang lebih dulu. (d2 pada gambar di bawah).

Misalnya, pengguna meminta langganan formulir aplikasi online untuk masuk ke perguruan tinggi dan permintaan dibatalkan jika pengguna tidak menerima balasan konfirmasi dalam jangka waktu tertentu.

Proses BPEL Klien membutuhkan aktivitas pemanggilan untuk mengirim permintaan dan aktivitas pengambilan dengan dua cabang - an onMessage cabang dan sebuah onAlarmcabang. Jika balasan datang setelah batas waktu kedaluwarsa, pesan masuk ke antrian surat mati.

Proses BPEL Layanan memerlukan aktivitas menerima untuk menerima permintaan masuk dan aktivitas pemanggilan untuk mengembalikan informasi yang diminta atau kesalahan.

Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi.

Dalam bab ini, kita akan belajar tentang interaksi asinkron dengan pengatur waktu notifikasi. Pertimbangkan poin-poin berikut yang terkait dengan interaksi asinkron -

  • Proses BPEL Klien mengirimkan permintaan ke Proses BPEL Layanan dan menunggu balasan, meskipun pemberitahuan dikirim setelah pengatur waktu berakhir.

  • Proses BPEL Klien terus menunggu balasan dari Proses BPEL Layanan bahkan setelah timer telah kedaluwarsa.

  • Proses BPEL Klien membutuhkan aktivitas cakupan yang berisi aktivitas pemanggilan untuk mengirim permintaan, dan aktivitas penerimaan untuk menerima balasan. ItuonAlarm penangan aktivitas ruang lingkup memiliki batas waktu dan instruksi tentang apa yang harus dilakukan ketika pengatur waktu berakhir.

  • Misalnya, tunggu 60 detik, lalu kirim peringatan yang menunjukkan bahwa proses tersebut memakan waktu lebih lama dari yang diharapkan.

  • Proses BPEL Layanan memerlukan aktivitas menerima untuk menerima permintaan masuk dan aktivitas pemanggilan untuk mengembalikan informasi yang diminta atau kesalahan.

  • Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi.

Pada bab ini, kita akan belajar tentang konsep Satu Permintaan dan Banyak Tanggapan.

  • Proses BPEL Klien mengirimkan satu permintaan ke Proses BPEL Layanan dan menerima banyak tanggapan sebagai balasannya.

    Misalnya, permintaan dapat memesan produk secara online, dan tanggapan pertama dapat berupa perkiraan waktu pengiriman, tanggapan kedua berupa konfirmasi pembayaran, dan tanggapan ketiga berupa pemberitahuan bahwa produk telah dikirim. Dalam contoh ini, jumlah dan jenis tanggapan diharapkan.

  • Proses BPEL Klien membutuhkan aktivitas pemanggilan untuk mengirim permintaan, dan aktivitas urutan dengan tiga aktivitas penerimaan.

  • Proses BPEL Layanan memerlukan aktivitas menerima untuk menerima pesan dari klien, dan atribut urutan dengan tiga aktivitas pemanggilan, satu untuk setiap balasan.

  • Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi.

Dalam bab ini, kita akan belajar tentang konsep satu permintaan dan satu dari dua kemungkinan tanggapan.

  • Proses BPEL Klien mengirimkan satu permintaan ke Proses BPEL Layanan dan menerima satu dari dua kemungkinan tanggapan.

    Misalnya, permintaan dapat berupa memesan produk secara online, dan tanggapan pertama dapat berupa pesan dalam stok, atau pesan stok habis.

  • Proses BPEL Klien membutuhkan yang berikut -

    • Aktivitas pemanggilan untuk mengirim permintaan.

    • Aktivitas pengambilan dengan dua cabang: satu onMessage untuk respons yang tersedia dan instruksi tentang apa yang harus dilakukan jika pesan yang tersedia diterima.

    • OnMessage kedua untuk respons out-of-stock dan instruksi tentang apa yang harus dilakukan jika pesan out-of-stock diterima.

  • Proses BPEL Layanan memerlukan aktivitas penerimaan untuk menerima pesan dari klien, dan aktivitas sakelar dengan dua cabang, satu dengan aktivitas pemanggilan yang mengirimkan pesan dalam stok jika item tersedia, dan cabang kedua dengan aktivitas pemanggilan pengiriman pesan kehabisan stok jika item tidak tersedia.

Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi.

Dalam bab ini, kita akan memahami konsep satu permintaan, tanggapan wajib, dan tanggapan opsional.

  • Layanan BPEL Klien mengirimkan satu permintaan ke Proses BPEL Layanan dan menerima satu atau dua tanggapan.

  • Di sini, permintaannya adalah memesan produk secara online. Jika produk tertunda, layanan mengirimkan pesan yang memberi tahu pelanggan. Bagaimanapun, layanan selalu mengirimkan pemberitahuan ketika barang dikirim.

  • Layanan BPEL Klien membutuhkan aktivitas cakupan yang berisi aktivitas pemanggilan untuk mengirim permintaan, dan aktivitas penerimaan untuk menerima balasan wajib. Untuk pesan opsional,onMessagepenangan aktivitas cakupan disetel bersama dengan petunjuk tentang apa yang harus dilakukan jika pesan opsional diterima (misalnya, memberi tahu Anda bahwa produk telah ditunda). Proses BPEL Klien menunggu untuk menerima balasan wajib. Jika balasan wajib diterima terlebih dahulu, Proses BPEL berlanjut tanpa menunggu balasan opsional.

  • Proses BPEL Layanan memerlukan aktivitas cakupan yang berisi aktivitas penerimaan dan aktivitas pemanggilan untuk mengirim pesan pengiriman wajib, dan aktivitas cakupan onAlarm penangan untuk mengirim pesan tunda opsional jika timer kedaluwarsa (misalnya, mengirim pesan tunda jika item tidak dikirim dalam 24 jam).

  • Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi.

Sekarang, kita akan mempelajari konsep pemrosesan parsial di BPEL.

  • Proses BPEL Klien mengirimkan permintaan ke Proses BPEL Layanan dan menerima tanggapan segera, tetapi pemrosesan berlanjut di sisi layanan.

  • Pola ini juga dapat mencakup beberapa panggilan balik, diikuti dengan pemrosesan jangka panjang.

  • Misalnya, klien mengirimkan permintaan untuk membeli paket liburan, dan layanan mengirimkan balasan langsung untuk mengonfirmasi pembelian, kemudian melanjutkan untuk memesan hotel, penerbangan, mobil sewaan, dan sebagainya.

  • Proses BPEL Klien membutuhkan aktivitas pemanggilan untuk setiap permintaan dan aktivitas penerimaan untuk setiap balasan untuk transaksi asinkron, atau hanya aktivitas pemanggilan untuk setiap transaksi sinkron.

  • Proses BPEL Layanan membutuhkan aktivitas menerima untuk setiap permintaan dari klien, dan aktivitas pemanggilan untuk setiap respons. Setelah tanggapan selesai, Proses BPEL Layanan sebagai layanan dapat melanjutkan pemrosesannya, menggunakan informasi yang dikumpulkan dalam transaksi untuk melakukan tugas-tugas yang diperlukan tanpa masukan lebih lanjut dari klien.

  • Seperti dengan semua aktivitas mitra, file Web Services Description Language (WSDL) mendefinisikan interaksi.

Kita akan mempelajari tentang berbagai interaksi aplikasi dengan BPEL di bab ini.

  • Ketika ada lebih dari dua aplikasi yang terlibat dalam sebuah transaksi.

  • Pola transaksi A-to-B-to-C-to-A ini dapat menangani banyak transaksi pada saat yang bersamaan. Oleh karena itu, diperlukan mekanisme untuk melacak kemana pesan pergi.

  • Ini dapat ditangani dengan menggunakan WS-Addressing atau set korelasi.

Kita telah membahas di salah satu bab sebelumnya bahwa Synchronous Web Service adalah satu, yang memberikan tanggapan langsung ke sebuah pemanggilan.

Pada tangkapan layar yang ditunjukkan di bawah ini, kami telah membuat Proses BPEL Sinkron yang memiliki aktivitas menerima untuk menerima permintaan dari pengguna. Aktivitas membalas secara bersamaan mengirimkan respons kembali.

Seperti yang telah dibahas sebelumnya, Asynchronous Web Service adalah salah satu yang mengirimkan permintaan ke layanan web lain dan menunggu tanggapannya.

Pada tangkapan layar yang ditunjukkan di bawah ini, kami telah membuat Proses BPEL Asynchronous yang memiliki aktivitas menerima untuk menerima permintaan dari pengguna. Aktivitas assign selanjutnya memberikan nilai ke elemen yang berbeda dalam permintaan.

Selanjutnya, aktivitas pemanggilan memanggil Aplikasi HelloWorld yang mengirimkan respons secara bersamaan dan yang ditangkap dalam aktivitas terima.

Lebih lanjut, kita memiliki aktivitas callback yang akhirnya menghasilkan keluaran dan mengirim respon secara asynchronous.

Jika Anda mengklik dua kali file receiveInput atau callbackClient, Anda akan melihat masing-masing hanya memiliki satu variabel.

receiveInput → inputVariable
callbackClient → outputVariable

Pada bab ini, kita akan memahami bagaimana aliran paralel bekerja di BPEL.

Apa itu Aktivitas Arus?

Aktivitas aliran biasanya berisi banyak aktivitas urutan, dan setiap urutan dilakukan secara paralel. Aktivitas aliran juga dapat berisi aktivitas lain.

Misalnya, dua callback asinkron dijalankan secara paralel, sehingga satu callback tidak harus menunggu callback lainnya selesai terlebih dahulu. Setiap respon disimpan dalam variabel global yang berbeda.

Dalam aktivitas aliran, kode BPEL menentukan jumlah cabang paralel. Namun, seringkali jumlah cabang yang dibutuhkan berbeda-beda tergantung pada informasi yang tersedia.

Apa itu Aktivitas FlowN?

Aktivitas flowN membuat beberapa aliran yang sama dengan nilai N, yang ditentukan pada waktu proses berdasarkan data yang tersedia dan logika dalam proses. Ada kenaikan variabel Indeks setiap kali cabang baru dibuat, hingga variabel indeks mencapai nilai N.

Aktivitas flowN melakukan aktivitas pada sejumlah elemen data yang berubah-ubah. Saat jumlah elemen berubah, proses BPEL akan menyesuaikan.

Cabang yang dibuat oleh flowN melakukan aktivitas yang sama, tetapi menggunakan data yang berbeda. Setiap cabang menggunakan variabel indeks untuk mencari variabel masukan. Variabel indeks dapat digunakan dalam ekspresi XPath untuk memperoleh data khusus untuk cabang tersebut.

BPEL menerapkan logika untuk membuat pilihan melalui percabangan bersyarat. Dua tindakan berbeda berdasarkan pencabangan bersyarat ditunjukkan di bawah ini -

Ganti Aktivitas

Dalam metode ini, Anda menyiapkan dua atau lebih cabang, dengan setiap cabang dalam bentuk ekspresi XPath. Jika ekspresi benar, maka cabang dijalankan. Jika ekspresi salah, maka proses BPEL berpindah ke kondisi cabang berikutnya, hingga menemukan kondisi cabang yang valid, menemukan cabang sebaliknya, atau kehabisan cabang. Jika lebih dari satu kondisi cabang benar, maka BPEL mengeksekusi cabang pertama yang benar.

Sementara Aktivitas

Anda dapat menggunakan aktivitas while untuk membuat loop sementara untuk memilih di antara dua tindakan.

Untuk memahami cara menggunakan penanganan kesalahan, kita perlu mempelajari arsitektur dasar Service Composite di Oracle SOA Suite.

  • Service components- Proses BPEL, Aturan Bisnis, Tugas Manusia, Mediator. Ini digunakan untuk membangun aplikasi komposit SOA.

  • Binding components - Buat koneksi antara komposit SOA dan dunia luar.

  • Services - Menyediakan titik masuk ke aplikasi komposit SOA.

  • Binding - Mendefinisikan protokol yang berkomunikasi dengan layanan seperti SOAP / HTTP, adaptor JCA, dll.

  • WSDL - Menentukan definisi layanan dari layanan web.

  • References - Memungkinkan aplikasi komposit SOA untuk mengirim pesan ke layanan eksternal

  • Wires - Mengaktifkan koneksi antara komponen layanan.

Jenis Kesalahan

Sekarang mari kita lihat berbagai jenis kesalahan.

Kesalahan bisnis

Terjadi saat aplikasi menjalankan aktivitas THROW atau INVOKE menerima kesalahan sebagai respons. Nama kesalahan ditentukan oleh komponen layanan proses BPEL. Penangan kesalahan menggunakan nama Fault dan variabel Fault menangkap kesalahan ini.

Kesalahan runtime

Ini dilemparkan oleh sistem. Kesalahan ini berhubungan denganRunTimeFaultMessage dan termasuk dalam

http://schemas.oracle.com/bpel/extensionnamespace.

Cara Penanganan Kesalahan

Pada bagian ini, kita akan belajar tentang berbagai cara penanganan kesalahan.

Aktivitas Lempar

Aktivitas melempar secara eksplisit melempar kesalahan. Blok catch menangkap kesalahan ini dan tindakan terkait dieksekusi karenanya.

  • Menggunakan aktivitas lemparan, Anda dapat membuang kesalahan bisnis & dalam lingkup yang dibuat, Anda dapat menangkap kesalahan ini dan mengarahkan ke pemanggil (konsumen) untuk mengambil tindakan.

  • Alih-alih pendekatan di atas, Anda melempar kesalahan yang sama yang tertangkap dalam aktivitas tangkap dari cakupan yang dibuat. Dalam lingkup utama, Anda bisa menangkap kesalahan ini menggunakan aktivitas catchall.

Kerangka Penangan Kesalahan (EHF)

2 file utama yang digunakan di EHF adalah -

  • Fault-Policy.xml
  • Fault-Bindings.xml

Setiap kali proses BPEL membuat kesalahan, EHF akan memeriksa apakah kesalahan tersebut ada di file Fault-Bindings.xml. Jika demikian, tindakan di file Fault-Policy.xml akan diambil. Jika tindakan tidak ditemukan, kesalahan akan terlempar dan akan ditangani di blok tangkap.

Kerangka kerja manajemen kesalahan (Fault-Policy.xml dan Fault-Bindings.xml) disimpan di dalam SOA Composite.

Penangan kesalahan seperti menangkap dan menangkap semua berada di dalam BPEL untuk menangkap semua kesalahan, tapi fault policies will only be executed when an invoke activity fails.

Dalam bab ini, kita akan melihat skenario berbeda yang terkait dengan pengiriman ulang proses yang salah.

Skenario A

Kode BPEL menggunakan kebijakan kesalahan dan kesalahan ditangani menggunakan aktivitas "atau intervensi manusia". Masalah ini kemudian ditandai sebagai Dapat Dipulihkan dan status instans disetel ke "Berjalan".

Skenario B

Kode BPEL menggunakan kebijakan kesalahan dan kesalahan ditangkap dan dilemparkan kembali menggunakan tindakan "ora-rethrow-fault". Masalah ini kemudian ditandai sebagai Dapat Dipulihkan dan status instans disetel ke "Faulted"; asalkan kesalahannya dapat dipulihkan (seperti URL tidak tersedia).

Ada beberapa metode untuk memasukkan kode Java dan Java EE dalam proses BPEL. Berikut adalah beberapa metode penting -

  • Bungkus sebagai layanan Simple Object Access Protocol (SOAP)

  • Sematkan potongan kode Java ke dalam proses BPEL dengan tag bpelx - exec

  • Gunakan fasad XML untuk menyederhanakan manipulasi DOM

  • Gunakan bpelx - exec metode bawaan

  • Gunakan kode Java yang dibungkus dalam antarmuka layanan

Aktivitas Java Embedding memungkinkan kita menambahkan aktivitas dalam proses BPEL. Kita dapat menulis cuplikan Java menggunakan pustaka JDK standar, API BPEL, Kelas Java khusus dan pihak ketiga yang disertakan dalam file JAR dalam komposit SCA yang diterapkan (di direktori SCA-INF / lib) dan Kelas dan pustaka Java yang tersedia di Classpath untuk SOA Waktu berjalan suite.

Java Embedding berarti fungsionalitas yang tersembunyi di dalam, dengan cara yang tidak terlalu terpisah. Kode Java sulit dipelihara. Dengan menyematkan Java di BPEL (berbasis XML), kami mulai menggabungkan teknologi, yang memerlukan keahlian berbeda serta XML yang mahal ke Java Object marshalling dan unmarshalling.

Kasus penggunaan terbaik untuk Java Embedding tampaknya untuk pembuatan log / penelusuran lanjutan atau untuk validasi / transformasi khusus. Namun, tidak untuk menggantikan kapabilitas bawaan mesin BPEL serta komponen lain di SOA Suite 11g dan adaptor yang menyertainya.

XPath terutama digunakan untuk memanipulasi XML dalam proses BPEL. Ada beberapa fungsi Xpath yang berharga yang dapat digunakan untuk memanipulasi XML. Mari kita lihat fungsinya di bawah ini.

bpel: getVaribleData (varName, partName, xpathStr)

Ini dapat digunakan untuk mengekstrak sekumpulan elemen dari variabel, menggunakan ekspresi XPath.

<bpel:copy>
   <bpel:from>
   <![CDATA[count(bpel:getVariableData(‘$Variable','$partName')/ns:return)]]>
   </bpel:from>
      <bpel:to variable = "itemNumber">
   </bpel:to>
</bpel:copy>

bpel: getLinkStatus ()

Ini dapat digunakan untuk mengevaluasi dan mengembalikan Boolean apakah link tertentu aktif atau tidak.

: getVariableProperty (string, string)

Ini berguna dalam mengekstraksi properti di Variabel.

: doXSLTTransform ()

Ini melakukan transformasi XSLT.

string ()

Ini dapat digunakan untuk mengekstrak konten teks dari elemen daripada menggunakan / text ().

string-length ()

Fungsi ini digunakan untuk menghitung panjang string. Tetapi operator! = Tampaknya tidak bekerja dengan keluaran dari fungsi ini. Jadi Anda bisa menggunakan> atau <lebih tepatnya menggunakan! =.

Nilai Boolean

Anda dapat menetapkan nilai boolean dengan fungsi boolean XPath.

<assign>
   <!-- copy from boolean expression function to the variable -->
   <copy>
      <from expression = "true()"/>
      <to variable = "output" part = "payload" query="/result/approved"/>
   </copy>
</assign>

Menetapkan Tanggal atau Waktu

Anda dapat menetapkan nilai saat ini dari bidang tanggal atau waktu dengan menggunakan fungsi Oracle BPEL XPath getCurrentDate, getCurrentTime, atau getCurrentDateTime.

<!-- execute the XPath extension function getCurrentDate() -->
<assign>
   <copy>
      <from expression = "xpath20:getCurrentDate()"/>
      <to variable = "output" part = "payload"
      query = "/invoice/invoiceDate"/>
   </copy>
</assign>

String Penggabungan

Daripada menyalin nilai dari satu variabel string (atau bagian variabel atau bidang) ke yang lain, Anda dapat melakukan manipulasi string terlebih dahulu, seperti menggabungkan beberapa string.

<assign>
   <!-- copy from XPath expression to the variable -->
   <copy>
      <from expression = "concat('Hello ',
      bpws:getVariableData('input', 'payload', '/p:name'))"/>
      <to variable = "output" part = "payload" query = "/p:result/p:message"/>
   </copy>
</assign>

Menetapkan Literal String

Anda dapat menetapkan literal string ke variabel di BPEL.

<assign>
   <!-- copy from string expression to the variable -->
   <copy>
      <from expression = "'GE'"/>
      <to variable = "output" part = "payload" query = "/p:result/p:symbol"/>
   </copy>
</assign>

Menetapkan Nilai Numerik

Anda dapat menetapkan nilai numerik dalam ekspresi XPath.

<assign>
   <!-- copy from integer expression to the variable -->
   <copy>
      <from expression = "100"/>
      <to variable = "output" part = "payload" query = "/p:result/p:quantity"/>
   </copy>
</assign>

Note - Beberapa fungsi XSLT digunakan untuk mengubah dokumen XML.

Korelasi BPEL mencocokkan pesan masuk dengan contoh proses tertentu. Saat Anda perlu mengaitkan data tertentu ke contoh tertentu dari proses bisnis, Anda menggunakan korelasi.

Misalnya, saat membuat proses yang memverifikasi nomor akun dan memeriksa batas kredit akun. Saat diverifikasi, proses membuat panggilan ke sistem lain untuk memeriksa inventaris dan, jika item tersedia, menghasilkan pesanan pembelian. Bagaimana pesanan pembelian mengetahui akun mana yang akan didebit? Jawaban atas pertanyaan ini adalah korelasi.

Kumpulan Korelasi

Kumpulan korelasi digunakan untuk mengidentifikasi contoh proses secara unik. Anda memberikan setiap kumpulan korelasi dengan nama yang unik dan lalu menentukannya dengan satu atau beberapa properti. Setiap properti memiliki nama dan tipe (misalnya, string atau integer).

Alias ​​Properti

Alias ​​properti untuk setiap properti dalam kumpulan korelasi perlu ditentukan. Alias ​​properti adalah pemetaan yang mengikat properti dengan nilai masukan atau keluaran.

Poin Penting

Simak poin-poin penting berikut terkait dengan Correlation Sets and Message Aggregation -

  • Proses yang berisi lebih dari satu aktivitas terima atau pilih harus memiliki kumpulan korelasi.

  • Kumpulan korelasi diinisialisasi dengan nilai dari proses pesan masuk atau keluar.

  • Jika Anda memiliki grup pesan yang terkait dengan satu proses tertentu, Anda bisa menyiapkan satu atau beberapa kumpulan korelasi untuk ditangani.

Layanan web asinkron biasanya membutuhkan waktu lama untuk memberikan respons dan dengan demikian, komponen layanan proses BPEL harus dapat berhenti, atau berhenti menunggu, dan melanjutkan dengan sisa aliran setelah jangka waktu tertentu. Anda dapat menggunakan aktivitas pick untuk mengkonfigurasi aliran BPEL baik untuk menunggu selama jangka waktu tertentu atau untuk terus menjalankan tugasnya. Untuk menyetel masa kedaluwarsa, Anda dapat menggunakan aktivitas menunggu. Untuk mengelola pesan, peristiwa dapat digunakan terutama saat proses bisnis menunggu panggilan balik dari layanan Web mitra.

Acara

BPEL mendukung dua jenis acara -

Acara Pesan

Peristiwa ini dipicu oleh pesan masuk melalui permintaan operasi pada jenis porta.

Acara Alarm

Peristiwa ini terkait dengan waktu dan dipicu baik setelah durasi tertentu atau pada waktu tertentu.

  • Namun, sering kali lebih berguna untuk menunggu lebih dari satu pesan, yang hanya akan muncul satu.

  • Peristiwa alarm berguna ketika Anda ingin proses menunggu panggilan balik selama jangka waktu tertentu, seperti 15 menit.

    • Jika tidak ada panggilan balik yang diterima, aliran proses berlanjut seperti yang dirancang.

    • Berguna dalam arsitektur berorientasi layanan yang digabungkan secara longgar, di mana Anda tidak dapat mengandalkan layanan Web yang selalu tersedia.

Pilih Aktivitas

Kegiatan memilih memiliki 2 cabang -

  • onMessage - kode di cabang ini sama dengan kode untuk menerima tanggapan sebelum batas waktu ditambahkan.

  • onAlarm - kondisi ini memiliki kode untuk waktu tunggu satu menit.

Tunggu Aktivitas

Aktivitas menunggu memungkinkan proses menunggu untuk jangka waktu tertentu atau hingga batas waktu tercapai. Salah satu kriteria kedaluwarsa harus ditentukan.

Proses BPEL dapat digunakan untuk layanan notifikasi. Prosesnya dapat dirancang untuk mengirimkan yang berikut -

  • email
  • pesan suara
  • olahpesan cepat (IM), atau
  • pemberitahuan layanan pesan singkat (SMS)

Untuk layanan yang disebutkan di atas, Anda dapat mengkonfigurasi saluran untuk pesan masuk dan keluar.

Sensor komposit dalam aplikasi SOA memberikan kemampuan untuk menentukan kolom yang dapat dilacak pada pesan dan memungkinkan Anda menemukan instance komposit tertentu dengan mencari kolom atau kolom di dalam pesan. Misalnya, sensor dapat didefinisikan untuk nomor pesanan dalam pesan, sehingga memungkinkan kita untuk menemukan contoh di mana nomor pesanan tersebut ditemukan.

Sensor komposit dapat didefinisikan dalam aplikasi SOA di beberapa komponen -

  • Komponen layanan (layanan terbuka)

  • Komponen referensi (referensi eksternal)

  • Mediator atau komponen BPEL yang telah berlangganan acara bisnis (menerbitkan acara tidak dapat memiliki sensor)

Berbagai Cara Mendefinisikan Sensor Komposit

Ada beberapa cara berbeda untuk menentukan sensor komposit -

  • Dengan menentukan variabel yang ada sebagai sensor.
  • Dengan ekspresi dengan bantuan pembuat ekspresi.
  • Dengan menggunakan properti (misalnya properti header pesan).

Sensor di Manajer Perusahaan

Menentukan sensor memungkinkan pencarian cepat untuk data dalam instance komposit di Konsol EM.

Di dasbor Konsol EM, pengguna dapat mencari instance dengan nama dan nilai sensor.

Di tab "Contoh Aliran", Anda dapat memilih sensor dari tarik-turun dan dapat menggunakan nilai seperti karakter pengganti untuk nilai sensor.

Aktivitas Baru telah ditambahkan di 2.0 yang menggantikan aktivitas di 1.1.

<forEach>

Aktivitas ini membantu mengulangi rangkaian aktivitas. Aktivitas tersebut menggantikan aktivitas FlowN di versi BPEL 1.1.

<repeatUntil>

Kegiatan ini berguna jika tubuh suatu kegiatan harus dilakukan setidaknya sekali. Kondisi ekspresi XPath dalam aktivitas repeatUntil dievaluasi setelah isi aktivitas selesai.

<if> - <elseif> - <else>

Aktivitas ini menggantikan aktivitas sakelar di BPEL 2.0. Aktivitas memungkinkan Anda untuk menentukan perilaku bersyarat untuk aktivitas tertentu untuk memutuskan antara dua cabang atau lebih. Hanya satu aktivitas yang dipilih untuk dieksekusi dari sekumpulan cabang.

<compensateScope>

Aktivitas ini membantu mengkompensasi cakupan anak yang ditentukan.

<rethrow>

Aktivitas ini telah ditambahkan ke penangan kesalahan. Ini memungkinkan Anda untuk mengembalikan kesalahan yang awalnya ditangkap oleh penangan kesalahan yang segera menutupinya.