Event Delivery Network allows publish-subscribe type of loose
coupling between SCA components. This is similar to JMS/AQ model except
that user is spared from remembering and using low level JMS
connectivity details. Instead, SOA framework neatly abstracts these
details in the Even Delivery Network so that users can purely focus on
publishing and subscribing to events.
This approach is highly useful when an event publisher doesn’t know about the number or type of potential subscribers beforehand. Events can be published/subscribed from both BPEL as well as Mediator components.
In the present example, we will discuss about an event published from BPEL and subscribed by Mediator component. Mediator component shall write the event information to a File on SOA Server to make sure event subscription has successfully been processed.
data:image/s3,"s3://crabby-images/70e17/70e17f168d21e4d44e334ebeda211335f83e946a" alt="image image"
Steps to implement above example:
Step 1. Publish Event using BPEL
Create an SOA project and name it EventDeliveryExample. Select “Composite with BPEL Process” template.
data:image/s3,"s3://crabby-images/20e41/20e41c7ac6c26a5a5d753a940f79c971787cdb2f" alt="image image"
Create one-way BPEL process and name it EventPublisherProcess. Use following screenshot for other parameter values.
data:image/s3,"s3://crabby-images/5ace3/5ace3ba35cf396a6e81fa9b4e1f462bac444d684" alt="image image"
Import Order.xsd into the project and select orderDetails as Input element for the BPEL process. Click OK to complete project creation.
data:image/s3,"s3://crabby-images/d2fb2/d2fb219c59228119e942a8ea1ac9931517a82c32" alt="image image"
data:image/s3,"s3://crabby-images/003bc/003bccf9a8f7758d4ea6151afb2696d57e21bdfa" alt="image image"
Open composite.xml and click on “Event Definition Creation” icon from top left corner of the window as shown below.
data:image/s3,"s3://crabby-images/2aa02/2aa026786c8c832904f327452219271b740481ab" alt="image image"
Specify “OrderEventDefinition” for EDL File Name.
data:image/s3,"s3://crabby-images/365ac/365aca75ac5174e31b22ed78b611d8aabf905fa0" alt="image image"
Click on “+” icon in the Events section to create a new event. Select orderDetails element for Element field. Specify “OrderPublishingEvent” for Name field. Click on OK to add event.
data:image/s3,"s3://crabby-images/825b9/825b91b1907ad295d11052ac6a94715e66f426a5" alt="image image"
Click OK from Event Definition dialog.
data:image/s3,"s3://crabby-images/a2667/a26678e7f57322406629bf9e319778c50a1c28be" alt="image image"
Open EventPublisherProcess from composite.xml. From Component Palette, drag and drop an Invoke activity on to BPEL process.
data:image/s3,"s3://crabby-images/58915/58915f1cd6784a22dcda729ac8f43425d8535aee" alt="image image"
Open Invoke_1 activity. Specify “Invoke_Event” for Name field. Select “Event” as Interaction Type. For Event, select “OrderPublishingEvent” created in the previous steps. Create a new event input variable. Click OK to close Invoke activity.
data:image/s3,"s3://crabby-images/190a4/190a4359c969619554317d9379d37c96c339a712" alt="image image"
data:image/s3,"s3://crabby-images/ca487/ca487523115b87a4eabcc4aed5151e0927ede085" alt="image image"
Drag and drop an Assign activity. Assign BPEL input variable to event’s input variable.
data:image/s3,"s3://crabby-images/ad56b/ad56b34b77698a459d2b712d7e4d19c728bafb2d" alt="image image"
This completes Event publishing part using BPEL.
Step 2: Subscribe to Event using Mediator component.
Drag and drop a Mediator component on to Components pane in composite.xml. Specify “MediatorSubscriber” as Name. Select “Subscribe to Events” Template. Select “OrderPublishingEvent” from Event section.
data:image/s3,"s3://crabby-images/b5b04/b5b04d877cb51cbee8bb372dc79c970553487924" alt="image image"
Now Mediator component has successfully subscribed to OrderPublishingEvent.
data:image/s3,"s3://crabby-images/cc4c6/cc4c66da0f2df0cb4c255ba5501bf77017133930" alt="image image"
Lets create a File Adapter to write file to SOA Server’s File System. Drag and drop a “File Adapter” on to “External References” pane.
From Adapter Configuration Wizard, click Next. Enter “OrderWriterService” for Service Name. Click Next and Next again. From Operation dialog, select “Write File” as Operation Type. Specify “WriteOrder” as Operation Name. Click Next.
data:image/s3,"s3://crabby-images/496aa/496aaa688401a13b3737f083881cec4ffd90efc6" alt="image image"
Enter appropriate Directory Name for Outgoing Files. Specify File Naming Convention as “Order_%SEQ%.txt”. This ensures Order file get a serial number suffix (Example: Order_1.txt, Order_2.txt). Click Next.
data:image/s3,"s3://crabby-images/e7c86/e7c863f06429b992307b1f69b309cfdb12b46edb" alt="image image"
In Messages section, click on “Define Schema For Native Format” icon next to URL field. Click Next.
data:image/s3,"s3://crabby-images/b0472/b0472e99324bf9bc608211e819cf39afefcb897f" alt="image image"
Leave default values in “Choose Type” screen.
data:image/s3,"s3://crabby-images/2c421/2c421db7812dd549049cd3b8b7741d65cc9b0b8e" alt="image image"
Save following text to Order.txt file and select this file for “File name” field.
ItemName,OrderType,PurchaseDate,FirstName,LastName,AddressLine1,AddressLine2,City,State,Zip,Country
CT,EXPRESS,2011-02-01,Josh,Roy,Flat 14 Sunrise Heights,12 Martin Road,London,Greater London,EXX 5XX,UK
data:image/s3,"s3://crabby-images/258ec/258ecc4d682370fd6a1db7319de9319f20b1b187" alt="image image"
Click Next and Next again. Enter appropriate names for Target Namespace. Specify OrderCollection and Order for multiple collection and single record elements respectively. Click Next and Next.
data:image/s3,"s3://crabby-images/ba5c5/ba5c545e01e0873dccb77d01d9cb9821b162e125" alt="image image"
From Field Properties section, select “Use the first record as the field names”. Click Next. In the final step, give an appropriate name for generated schema and Finish.
data:image/s3,"s3://crabby-images/946b2/946b2571492c8051276ddc6e5f9743d49d12403e" alt="image image"
From Messages section, click Next and Finish.
data:image/s3,"s3://crabby-images/5f2f2/5f2f2fe02616ea377ef1d54410fba04121a4d918" alt="image image"
In composite.xml, wire MediatorSubscriber and OrderWriterService.
data:image/s3,"s3://crabby-images/111b8/111b8c73ea99820b22e08d7a9d74d5328b7b6ca5" alt="image image"
Double click on MediatorSubcriber. In Static Routing section, click on Transformation icon next to “Transform Using” field. Select “Create New Mapper File” and leave the default name. Click OK.
data:image/s3,"s3://crabby-images/b5dd3/b5dd3d7bb952fcff335c0dc262baa86d8c7da3d6" alt="image image"
Click on orderDetails in <sources> and drop on to OrderCollection element in <target>. Save All.
data:image/s3,"s3://crabby-images/16f56/16f5615f27b4f86a9ff5b59ebcac60a81596c49f" alt="image image"
Finally, Deploy EventDeliveryExample project. Launch the process by specifying values in Test screen.
data:image/s3,"s3://crabby-images/041d0/041d00140c7fed126834ad19a187bacd24e12e4a" alt="image image"
Order_1.txt should have been created in Outgoing File Directory with the values entered in above screen. This completes the implementation.
This approach is highly useful when an event publisher doesn’t know about the number or type of potential subscribers beforehand. Events can be published/subscribed from both BPEL as well as Mediator components.
In the present example, we will discuss about an event published from BPEL and subscribed by Mediator component. Mediator component shall write the event information to a File on SOA Server to make sure event subscription has successfully been processed.
data:image/s3,"s3://crabby-images/70e17/70e17f168d21e4d44e334ebeda211335f83e946a" alt="image image"
Steps to implement above example:
Step 1. Publish Event using BPEL
Create an SOA project and name it EventDeliveryExample. Select “Composite with BPEL Process” template.
data:image/s3,"s3://crabby-images/00b12/00b12c1a63effbb31f62a5b8ed46b794035955ca" alt="image image"
data:image/s3,"s3://crabby-images/20e41/20e41c7ac6c26a5a5d753a940f79c971787cdb2f" alt="image image"
Create one-way BPEL process and name it EventPublisherProcess. Use following screenshot for other parameter values.
data:image/s3,"s3://crabby-images/5ace3/5ace3ba35cf396a6e81fa9b4e1f462bac444d684" alt="image image"
Import Order.xsd into the project and select orderDetails as Input element for the BPEL process. Click OK to complete project creation.
data:image/s3,"s3://crabby-images/d2fb2/d2fb219c59228119e942a8ea1ac9931517a82c32" alt="image image"
data:image/s3,"s3://crabby-images/003bc/003bccf9a8f7758d4ea6151afb2696d57e21bdfa" alt="image image"
Open composite.xml and click on “Event Definition Creation” icon from top left corner of the window as shown below.
data:image/s3,"s3://crabby-images/2aa02/2aa026786c8c832904f327452219271b740481ab" alt="image image"
Specify “OrderEventDefinition” for EDL File Name.
data:image/s3,"s3://crabby-images/365ac/365aca75ac5174e31b22ed78b611d8aabf905fa0" alt="image image"
Click on “+” icon in the Events section to create a new event. Select orderDetails element for Element field. Specify “OrderPublishingEvent” for Name field. Click on OK to add event.
data:image/s3,"s3://crabby-images/825b9/825b91b1907ad295d11052ac6a94715e66f426a5" alt="image image"
Click OK from Event Definition dialog.
data:image/s3,"s3://crabby-images/a2667/a26678e7f57322406629bf9e319778c50a1c28be" alt="image image"
Open EventPublisherProcess from composite.xml. From Component Palette, drag and drop an Invoke activity on to BPEL process.
data:image/s3,"s3://crabby-images/58915/58915f1cd6784a22dcda729ac8f43425d8535aee" alt="image image"
Open Invoke_1 activity. Specify “Invoke_Event” for Name field. Select “Event” as Interaction Type. For Event, select “OrderPublishingEvent” created in the previous steps. Create a new event input variable. Click OK to close Invoke activity.
data:image/s3,"s3://crabby-images/190a4/190a4359c969619554317d9379d37c96c339a712" alt="image image"
data:image/s3,"s3://crabby-images/ca487/ca487523115b87a4eabcc4aed5151e0927ede085" alt="image image"
Drag and drop an Assign activity. Assign BPEL input variable to event’s input variable.
data:image/s3,"s3://crabby-images/6c552/6c552cbeb7f615511327152740a9786f7b8bcd8e" alt="image image"
data:image/s3,"s3://crabby-images/ad56b/ad56b34b77698a459d2b712d7e4d19c728bafb2d" alt="image image"
This completes Event publishing part using BPEL.
Step 2: Subscribe to Event using Mediator component.
Drag and drop a Mediator component on to Components pane in composite.xml. Specify “MediatorSubscriber” as Name. Select “Subscribe to Events” Template. Select “OrderPublishingEvent” from Event section.
data:image/s3,"s3://crabby-images/b5b04/b5b04d877cb51cbee8bb372dc79c970553487924" alt="image image"
Now Mediator component has successfully subscribed to OrderPublishingEvent.
data:image/s3,"s3://crabby-images/cc4c6/cc4c66da0f2df0cb4c255ba5501bf77017133930" alt="image image"
Lets create a File Adapter to write file to SOA Server’s File System. Drag and drop a “File Adapter” on to “External References” pane.
From Adapter Configuration Wizard, click Next. Enter “OrderWriterService” for Service Name. Click Next and Next again. From Operation dialog, select “Write File” as Operation Type. Specify “WriteOrder” as Operation Name. Click Next.
data:image/s3,"s3://crabby-images/ee0e4/ee0e489890b29e3c1efe941822169980206e000d" alt="image image"
data:image/s3,"s3://crabby-images/496aa/496aaa688401a13b3737f083881cec4ffd90efc6" alt="image image"
Enter appropriate Directory Name for Outgoing Files. Specify File Naming Convention as “Order_%SEQ%.txt”. This ensures Order file get a serial number suffix (Example: Order_1.txt, Order_2.txt). Click Next.
data:image/s3,"s3://crabby-images/e7c86/e7c863f06429b992307b1f69b309cfdb12b46edb" alt="image image"
In Messages section, click on “Define Schema For Native Format” icon next to URL field. Click Next.
data:image/s3,"s3://crabby-images/399b4/399b4c74846c194a60e3c92313d09797020ecd5c" alt="image image"
data:image/s3,"s3://crabby-images/b0472/b0472e99324bf9bc608211e819cf39afefcb897f" alt="image image"
Leave default values in “Choose Type” screen.
data:image/s3,"s3://crabby-images/2c421/2c421db7812dd549049cd3b8b7741d65cc9b0b8e" alt="image image"
Save following text to Order.txt file and select this file for “File name” field.
ItemName,OrderType,PurchaseDate,FirstName,LastName,AddressLine1,AddressLine2,City,State,Zip,Country
CT,EXPRESS,2011-02-01,Josh,Roy,Flat 14 Sunrise Heights,12 Martin Road,London,Greater London,EXX 5XX,UK
data:image/s3,"s3://crabby-images/258ec/258ecc4d682370fd6a1db7319de9319f20b1b187" alt="image image"
Click Next and Next again. Enter appropriate names for Target Namespace. Specify OrderCollection and Order for multiple collection and single record elements respectively. Click Next and Next.
data:image/s3,"s3://crabby-images/ba5c5/ba5c545e01e0873dccb77d01d9cb9821b162e125" alt="image image"
From Field Properties section, select “Use the first record as the field names”. Click Next. In the final step, give an appropriate name for generated schema and Finish.
data:image/s3,"s3://crabby-images/946b2/946b2571492c8051276ddc6e5f9743d49d12403e" alt="image image"
From Messages section, click Next and Finish.
data:image/s3,"s3://crabby-images/5f2f2/5f2f2fe02616ea377ef1d54410fba04121a4d918" alt="image image"
In composite.xml, wire MediatorSubscriber and OrderWriterService.
data:image/s3,"s3://crabby-images/111b8/111b8c73ea99820b22e08d7a9d74d5328b7b6ca5" alt="image image"
Double click on MediatorSubcriber. In Static Routing section, click on Transformation icon next to “Transform Using” field. Select “Create New Mapper File” and leave the default name. Click OK.
data:image/s3,"s3://crabby-images/b5dd3/b5dd3d7bb952fcff335c0dc262baa86d8c7da3d6" alt="image image"
Click on orderDetails in <sources> and drop on to OrderCollection element in <target>. Save All.
data:image/s3,"s3://crabby-images/16f56/16f5615f27b4f86a9ff5b59ebcac60a81596c49f" alt="image image"
Finally, Deploy EventDeliveryExample project. Launch the process by specifying values in Test screen.
data:image/s3,"s3://crabby-images/041d0/041d00140c7fed126834ad19a187bacd24e12e4a" alt="image image"
Order_1.txt should have been created in Outgoing File Directory with the values entered in above screen. This completes the implementation.
You can download the complete JDeveloper project from here.
No comments:
Post a Comment