Skip Headers
Oracle® Fusion Middleware Developer's Guide for Oracle SOA Suite
11g Release 1 (11.1.1.6.1)

Part Number E10224-12
Go to Documentation Home
Home
Go to Book List
Book List
Go to Table of Contents
Contents
Go to Index
Index
Go to Feedback page
Contact Us

Go to previous page
Previous
Go to next page
Next
PDF · Mobi · ePub

9 Using Correlation Sets and Message Aggregation

This chapter describes how to use correlation sets to ensure that asynchronous callbacks locate the appropriate client. It also describes how to use aggregation patterns to route messages to the same instance.

This chapter includes the following sections:

9.1 Using Correlation Sets in an Asynchronous Service

Correlation sets provide another method for directing web service responses to the correct BPEL process service component instance. You can use correlation sets to identify asynchronous messages to ensure that asynchronous callbacks locate the appropriate client.

Correlation sets are a BPEL mechanism that provides for the correlation of asynchronous messages based on message body contents. To use this method, define the correlation sets in your .bpel file. This method is designed for services that do not support WS-Addressing or for certain sophisticated conversation patterns, for example, when the conversation is in the form A > B > C > A instead of A > B > A.

This section describes how to use correlation sets in an asynchronous service with Oracle JDeveloper. Correlation sets enable you to correlate asynchronous messages based on message body contents. You define correlation sets when interactions are not simple invoke-receive activities. This example illustrates how to use correlation sets for a process having three receive activities with no associated invoke activities.

9.1.1 How to Use Correlation Sets in an Asynchronous Service

This section describes the steps to perform to use correlation sets in an asynchronous service.

9.1.1.1 Step 1: Creating a Project

To create a project:

  1. Start Oracle JDeveloper.

  2. From the File main menu, select New > Applications.

  3. Select SOA Application, and click OK.

    The Create SOA Application Wizard appears.

  4. In the Application Name field, enter MyCorrelationSetApp.

  5. Accept the default values for all remaining settings, and click Next.

  6. In the Project Name field, enter MyCorrelationSetComposite.

  7. Accept the default values for all remaining settings, and click Next.

  8. In the Composite Template section, select Composite With BPEL Process, and click Finish.

    The Create BPEL Process dialog appears.

  9. Enter the values shown in Table 9-1.

    Table 9-1 Create BPEL Process Dialog Fields and Values

    Field Value

    Name

    Enter MyCorrelationSet.

    Template

    Select Asynchronous BPEL Process.

    Expose as a SOAP Service

    Select the checkbox. After process creation, note the SOAP service that appears in the Exposed Services swimlane. This service provides the entry point to the composite application from the outside world.


  10. Accept the default values for all remaining settings, and click OK.

9.1.1.2 Step 2: Configuring Partner Links and File Adapter Services

You now create three partner links that use the SOAP service.

This section contains these topics:

  • You create an initial partner link with an adapter service for reading a loan application.

  • You create a second partner link with an adapter service for reading an application response.

  • You create a third partner link with an adapter service for reading a customer response.

9.1.1.2.1 Creating an Initial Partner Link and File Adapter Service

To create an initial partner link and file adapter service:

  1. Double-click the MyCorrelationSet BPEL process.

  2. In the Component Palette, expand BPEL Constructs.

  3. Drag an initial Partner Link activity into the right swimlane of the designer.

  4. Click the third icon at the top (the Service Wizard icon). This starts the Adapter Configuration Wizard, as shown in Figure 9-1.

    Figure 9-1 Adapter Configuration Wizard Startup

    Description of Figure 9-1 follows
    Description of "Figure 9-1 Adapter Configuration Wizard Startup"

  5. In the Configure Service or Adapter dialog, select File Adapter and click OK.

  6. In the Welcome dialog, click Next.

  7. In the Service Name field of the Service Name dialog, enter FirstReceive and click Next.

  8. In the Adapter Interface dialog, accept the default settings and click Next.

  9. In the Operation dialog, select Read File as the Operation Type and click Next. The Operation Name field is automatically filled in with Read.

  10. Above the Directory for Incoming Files (physical path) field, click Browse.

  11. Select a directory from which to read files (for this example, C:\files\receiveprocess\FirstInputDir is selected).

  12. Click Select.

  13. Click Next.

  14. In the File Filtering dialog, enter appropriate file filtering parameters.

  15. Click Next.

  16. In the File Polling dialog, enter appropriate file polling parameters.

  17. Click Next.

  18. In the Messages dialog, click Browse next to the URL field to display the Type Chooser dialog.

  19. Select an appropriate XSD schema file. For this example, Book1_4.xsd is the schema and LoanAppl is the schema element selected.

  20. Click OK.

    The URL field (Book1_4.xsd for this example) and the Schema Element field (LoanAppl for this example) are filled in.

  21. Click Next.

  22. Click Finish.

    You are returned to the Partner Link dialog. All other fields are automatically completed. The dialog looks as shown in Table 9-2:

    Table 9-2 Partner Link Dialog Fields and Values

    Field Value

    Name

    FirstReceive

    WSDL URL

    directory_path/FirstReceive.wsdl

    Partner Link Type

    Read_plt

    Partner Role

    Leave unspecified.

    My Role

    Read_role


  23. Click OK.

9.1.1.2.2 Creating a Second Partner Link and File Adapter Service

To create a second partner link and file adapter service:

  1. Drag a second PartnerLink activity beneath the FirstReceive partner link activity.

  2. At the top, click the third icon (the Service Wizard icon).

  3. In the Configure Service or Adapter dialog, select File Adapter and click OK.

  4. In the Welcome dialog, click Next.

  5. In the Adapter Type dialog, select File Adapter and click Next.

  6. In the Service Name field of the Service Name dialog, enter SecondFileRead and click Next. This name must be unique from the one you entered in Step 7 of Section 9.1.1.2.1, "Creating an Initial Partner Link and File Adapter Service."

  7. In the Adapter Interface dialog, accept the default settings and click Next.

  8. In the Operation dialog, select Read File as the Operation Type.

  9. In the Operation Name field, change the name to Read1.

  10. Click Next.

  11. Select Directory Names are Specified as Physical Path.

  12. Above the Directory for Incoming Files (physical path) field, click Browse.

  13. Select a directory from which to read files (for this example, C:\files\receiveprocess\SecondInputDir is entered).

  14. Click Select.

  15. Click Next.

  16. Enter appropriate file filtering parameters in the File Filtering dialog.

  17. Click Next.

  18. Enter appropriate file polling parameters in the File Polling dialog.

  19. Click Next.

  20. Next to the URL field in the Messages dialog, click Browse to display the Type Chooser dialog.

  21. Select an appropriate XSD schema file. For this example, Book1_5.xsd is the schema and LoanAppResponse is the schema element selected.

  22. Click OK.

    The URL field (Book1_5.xsd for this example) and the Schema Element field (LoanAppResponse for this example) are filled in.

  23. Click Next.

  24. Click Finish.

    You are returned to the Partner Link dialog. All other fields are automatically completed. The dialog looks as shown in Table 9-3:

    Table 9-3 Partner Link Dialog Fields and Values

    Field Value

    Name

    SecondReceive

    WSDL URL

    directory_path/SecondFileRead.wsdl

    Partner Link Type

    Read1_plt

    Partner Role

    Leave unspecified.

    My Role

    Read1_role


  25. Click OK.

9.1.1.2.3 Creating a Third Partner Link and File Adapter Service

To create a third partner link and file adapter service:

  1. Drag a third PartnerLink activity beneath the SecondReceive partner link activity.

  2. At the top, click the third icon (the Service Wizard icon).

  3. In the Configure Service or Adapter dialog, select File Adapter and click OK.

  4. In the Welcome dialog, click Next.

  5. In the Adapter Type dialog, select File Adapter and click Next.

  6. In the Service Name field of the Service Name dialog, enter ThirdFileRead and click Next. This name must be unique from the one you entered in Step 7 of Section 9.1.1.2.1, "Creating an Initial Partner Link and File Adapter Service" and Step 6 of Section 9.1.1.2.2, "Creating a Second Partner Link and File Adapter Service."

  7. In the Adapter Interface dialog, accept the default settings and click Next.

  8. In the Operation dialog, select Read File as the Operation Type.

  9. In the Operation Name field, change the name to Read2. This name must be unique.

  10. Click Next.

  11. Select Directory Names are Specified as Physical Path.

  12. Above the Directory for Incoming Files (physical path) field, click Browse.

  13. Select a directory from which to read files (for this example, C:\files\receiveprocess\ThirdInputDir is entered).

  14. Click Select.

  15. Click Next.

  16. Enter appropriate file filtering parameters in the File Filtering dialog.

  17. Click Next.

  18. Enter appropriate file polling parameters in the File Polling dialog.

  19. Click Next.

  20. Next to the URL field in the Messages dialog, click Browse to display the Type Chooser dialog.

  21. Select an appropriate XSD schema file. For this example, Book1_6.xsd is the schema and CustResponse is the schema element selected.

  22. Click OK.

    The URL field (Book1_6.xsd for this example) and the Schema Element field (CustResponse for this example) are filled in.

  23. Click Next.

  24. Click Finish.

    You are returned to the Partner Link dialog. All other fields are automatically completed. The dialog looks as shown in Table 9-4:

    Table 9-4 Partner Link Dialog Fields and Values

    Field Value

    Name

    ThirdReceive

    WSDL URL

    directory_path/ThirdFileRead.wsdl

    Partner Link Type

    Read2_plt

    Partner Role

    Leave unspecified.

    My Role

    Read2_role


  25. Click OK.

9.1.1.3 Step 3: Creating Three Receive Activities

You now create three receive activities; one for each partner link. The receive activities specify the partner link from which to receive information.

9.1.1.3.1 Creating an Initial Receive Activity

To create an initial receive activity:

  1. Expand BPEL Constructs in the Component Palette.

  2. Drag a Receive activity beneath the receiveInput receive activity in the designer.

  3. Double-click the receive icon to display the Receive dialog.

  4. Enter the details described in Table 9-5 to associate the first partner link (FirstReceive) with the first receive activity:

    Table 9-5 Receive Dialog Fields and Values

    Field Value

    Name

    receiveFirst

    Partner Link

    FirstReceive

    Create Instance

    Select this checkbox.


    The Operation (Read) field is automatically filled in.

  5. To the right of the Variable field, click the first icon. This is the automatic variable creation icon.

  6. In the Create Variable dialog, click OK.

    A variable named receiveFirst_Read_InputVariable is automatically created in the Variable field.

  7. Ensure that you selected the Create Instance checkbox, as mentioned in Step 4.

  8. Click OK.

9.1.1.3.2 Creating a Second Receive Activity

To create a second receive activity:

  1. From the Component Palette, drag a second Receive activity beneath the receiveFirst receive activity.

  2. Double-click the receive icon to display the Receive dialog.

  3. Enter the details described in Table 9-6 to associate the second partner link (SecondReceive) with the second receive activity:

    Table 9-6 Receive Dialog Fields and Values

    Field Value

    Name

    receiveSecond

    Partner Link

    SecondFileRead

    Create Instance

    Do not select this checkbox.


    The Operation (Read1) field is automatically filled in.

  4. To the right of the Variable field, click the first icon.

  5. In the Create Variable dialog, click OK.

    A variable named receiveSecond_Read1_InputVariable is automatically created in the Variable field.

  6. Click OK.

9.1.1.3.3 Creating a Third Receive Activity

To create a third receive activity:

  1. From the Component Palette, drag a third Receive activity beneath the receiveSecond receive activity.

  2. Double-click the receive icon to display the Receive dialog.

  3. Enter the details described in Table 9-7 to associate the third partner link (ThirdReceive) with the third receive activity:

    Table 9-7 Receive Dialog Fields and Values

    Field Value

    Name

    receiveThird

    Partner Link

    ThirdFileRead

    Create Instance

    Do not select this checkbox.


    The Operation (Read2) field is automatically filled in.

  4. To the right of the Variable field, click the first icon.

  5. In the Create Variable dialog, click OK.

    A variable named receiveThird_Read2_InputVariable is automatically created in the Variable field.

  6. Click OK.

    Each receive activity is now associated with a specific partner link.

9.1.1.4 Step 4: Creating Correlation Sets

You now create correlation sets. A set of correlation tokens is a set of properties shared by all messages in the correlated group.

9.1.1.4.1 Creating an Initial Correlation Set

To create an initial correlation set:

  1. In the Structure window of Oracle JDeveloper, right-click Correlation Sets and select Expand All Child Nodes.

  2. In the second Correlation Sets folder, right-click and select Create Correlation Set.

  3. In the Name field of the Create Correlation Set dialog, enter CorrelationSet1.

  4. In the Properties section, click the Add icon to display the Property Chooser dialog.

  5. Select Properties, then click the Add icon (first icon at the top) to display the Create Property dialog.

  6. In the Name field, enter NameCorr.

  7. To the right of the Type field, click the Browse icon.

  8. In the Type Chooser dialog, select string and click OK.

  9. Click OK to close the Create Property dialog, the Property Chooser dialog, and the Create Correlation Set dialog.

9.1.1.4.2 Creating a Second Correlation Set

To create a second correlation set:

  1. Return to the Correlation Sets section in the Structure window of Oracle JDeveloper.

  2. Right-click the Correlation Sets folder and select Create Correlation Set.

  3. In the Name field of the Create Correlation Set dialog, enter CorrelationSet2.

  4. In the Properties section, click the Add icon to display the Property Chooser dialog.

  5. Select Properties, then click the Add icon to display the Create Property dialog.

  6. In the Name field, enter IDCorr.

  7. To the right of the Type field, click the Browse icon.

  8. In the Type Chooser dialog, select double and click OK.

  9. Click OK to close the Create Property dialog, the Property Chooser dialog, and the Create Correlation Set dialog.

9.1.1.5 Step 5: Associating Correlation Sets with Receive Activities

You now associate the correlation sets with the receive activities. You perform the following correlation set tasks:

  • For the first correlated group, the first and second receive activities are correlated with the CorrelationSet1 correlation set.

  • For the second correlated group, the second and third receive activities are correlated with the CorrelationSet2 correlation set.

9.1.1.5.1 Associating the First Correlation Set with a Receive Activity

To associate the first correlation set with a receive activity:

  1. Double-click the receiveFirst receive activity to display the Receive dialog.

  2. Click the Correlations tab.

  3. Click the Add icon to display the correlation set dropdown list.

  4. Select CorrelationSet1.

  5. Click the Initiate column to display a dropdown list, and select yes. When set to yes, the set is initiated with the values of the properties occurring in the message being exchanged.

  6. Click OK.

9.1.1.5.2 Associating the Second Correlation Set with a Receive Activity

To associate the second correlation set with a receive activity:

  1. Double-click the receiveSecond receive activity to display the Receive dialog.

  2. Click the Correlations tab.

  3. Click the Add icon to display the correlation set dropdown list.

  4. Select CorrelationSet2, then click OK.

  5. Click the Initiate column to display a dropdown list, and select yes.

  6. Click Add again and select CorrelationSet1.

  7. Click OK.

  8. Click the Initiate column to display a dropdown list, and select no for CorrelationSet1.

  9. Click OK.

    This groups the first and second receive activities into a correlated group.

9.1.1.5.3 Associating the Third Correlation Set with a Receive Activity

To associate the third correlation set with a receive activity:

  1. Double-click the receiveThird receive activity to display the Receive dialog.

  2. Click the Correlations tab.

  3. Click the Add icon.

  4. Select CorrelationSet2.

  5. Set the Initiate column to no for CorrelationSet2.

  6. Click OK.

    This groups the second and third receive activities into a second correlated group.

9.1.1.6 Step 6: Creating Property Aliases

Property aliases enable you to map a global property to a field in a specific message part. This action enables the property name to become an alias for the message part and location. The alias can be used in XPath expressions.

9.1.1.6.1 Creating Property Aliases for NameCorr

You create the following two property aliases for the NameCorr correlation set:

  • Map NameCorr to the LoanAppl message type part of the receiveFirst receive activity. This receive activity is associated with the FirstReceive partner link (defined by the FirstReceive.wsdl file).

  • Map NameCorr to the incoming LoanAppResponse message type part of the receiveSecond receive activity. This receive activity is associated with the SecondReceive partner link (defined by the SecondFileRead.wsdl file).

To create property aliases for NameCorr:

  1. In the Structure window of Oracle JDeveloper, right-click Property Aliases.

  2. Select Create Property Alias.

  3. From the Property list, select NameCorr.

  4. Expand and select Message Types > Partner Link > FirstReceive > FirstReceive.wsdl > Message Types > LoanAppl_msg > Part - LoanAppl.

  5. In the Query field, press Ctrl+Space to define the following XPath expression:

    /ns2:LoanAppl/ns2:Name
    
  6. Click OK.

  7. Repeat Step 1 through Step 3 to create a second property alias for NameCorr.

  8. Expand and select Message Types > Project WSDL Files > SecondFileRead.wsdl > Message Types > LoanAppResponse_msg > Part - LoanAppResponse.

  9. In the Query field, press Ctrl+Space to define the following XPath expression:

    /ns4:LoanAppResponse/ns4:APR
    
  10. Click OK.

9.1.1.6.2 Creating Property Aliases for IDCorr

You create the following two property aliases for the IDCorr correlation set:

  • Map IDCorr to the LoanAppResponse message type part of the receiveSecond receive activity. This receive activity is associated with the SecondReceive partner link (defined by the SecondFileRead.wsdl file).

  • Map IDCorr to the CustResponse message type part of the receiveThird receive activity. This receive activity is associated with the ThirdReceive partner link (defined by the ThirdFileRead.wsdl file).

To create property aliases for IDCorr:

  1. In the Structure window, right-click Property Aliases.

  2. Select Create Property Alias.

  3. In the Property list, select IDCorr.

  4. Expand and select Message Types > Project WSDL Files > SecondFileRead.wsdl > Message Types > LoanAppResponse_msg > Part - LoanAppResponse.

  5. In the Query field, press Ctrl+Space to define the following XPath expression:

    /ns4:LoanAppResponse/ns4:APR
    
  6. Click OK.

  7. Repeat Step 1 through Step 3 to create a second property alias for IDCorr.

  8. Expand and select Message Types > Project WSDL Files > ThirdFileRead.wsdl > Message Types > CustResponse_msg > Part - CustResponse.

  9. In the Query field, press Ctrl+Space to define the following XPath expression:

    /ns6:CustResponse/ns6:APR
    

    Design is now complete.

  10. Click OK.

9.1.1.7 Step 7: Reviewing WSDL File Content

To review WSDL file content:

  1. Refresh the Application Navigator.

    The NameCorr and IDCorr correlation set properties are defined in the MyCorrelationSet_Properties.wsdl file in the Application Navigator. Example 9-1 provides an example.

    Example 9-1 Correlation Set Properties

    <definitions
         name="properties"
         targetNamespace="http://xmlns.oracle.com/MyCorrelationSet/correlationset"
         xmlns="http://schemas.xmlsoap.org/wsdl/"
         xmlns:bpws="http://schemas.xmlsoap.org/ws/2003/03/business-process/"
         xmlns:plnk="http://schemas.xmlsoap.org/ws/2003/05/partner-link/"
         xmlns:xsd="http://www.w3.org/2001/XMLSchema">
        <bpws:property name="NameCorr" type="xsd:string"/>
        <bpws:property name="IDCorr" type="xsd:double"/>
    </definitions>
    

    The property aliases are defined in the MyCorrelationSet.wsdl file, as shown in Example 9-2:

    Example 9-2 Property Aliases

    <bpws:propertyAlias propertyName="ns1:NameCorr"
     messageType="ns3:LoanAppl_msg"
     part="LoanAppl" query="/ns2:LoanAppl/ns2:Name"/>
    
    <bpws:propertyAlias propertyName="ns1:NameCorr" 
     messageType="ns5:LoanAppResponse_msg" 
     part="LoanAppResponse" query="/ns4:LoanAppResponse/ns4:APR"/>
    
    <bpws:propertyAlias propertyName="ns1:IDCorr" 
     messageType="ns5:LoanAppResponse_msg" 
     part="LoanAppResponse" query="/ns4:LoanAppResponse/ns4:APR"/>
    
    <bpws:propertyAlias propertyName="ns1:IDCorr" 
     messageType="ns7:CustResponse_msg" 
     part="CustResponse" query="/ns6:CustResponse/ns6:APR"/>
    

    Because the BPEL process service component is not created as a web services provider in this example, the MyCorrelationSet.wsdl file is not referenced in the BPEL process service component. Therefore, you must import the MyCorrelationSet.wsdl file inside the FirstReceive.wsdl file to reference the correlation sets defined in the former WSDL. Example 9-3 provides an example.

    Example 9-3 WSDL File Import

    <import namespace="http://xmlns.oracle.com/MyCorrelationSet"
     location="MyCorrelationSet.wsdl"/>
    

9.1.2 What You May Need to Know About Conversion IDs and Different Composite Revisions

Do not use the same conversion ID for different revisions of a SOA composite application. When correlation sets are used in a BPEL process, you have explicit control over the conversation ID value. Oracle SOA Suite does not interfere or add restrictions on conversation ID value generation. This situation means that even though it appears that Oracle SOA Suite is generating the same conversation ID for different revisions, you actually control this behavior. Oracle SOA Suite suite does not restrict you from using the same conversation ID for different instances of different revisions.

If you do not use correlation sets, the conversation ID generated is unique and this is not a problem because Oracle SOA Suite decides which conversation ID to generate, and not you.

Oracle SOA Suite does not execute a revision check for callback routing. Routing of callback messages is only based on the following:

  • Conversation ID: This is calculated based on the input value and correlation set. If you use the same correlation set for two revisions of processes and enter the same input when creating an instance, both revisions subscribe using the same conversation ID. This causes confusion where a callback for one revision is delivered to another revision.

  • Operation name (is the same for both revisions).

  • BPEL service component name (is also the same for both revisions).

The concept of a revision number is applicable to Oracle SOA composite applications, and is not part of the BPEL specification. This is why it is not used as part of the routing decision.

There is another complication in which adding a revision as part of callback routing causes problems. When sending a callback, you also specify the endpoint URL. If the endpoint URL does not contain the composite revision (which is extremely likely), the message is assumed to be routed to the default revision. If Oracle SOA Suite runtime adds a revision check as part of callback routing, the callback for the nondefault revision instance is never possible.

For example, assume you have the following BPEL process:

  • An entry receive activity named receive_1 (on which a correlation set is used)

  • An invoke activity, which invokes a web service

  • A receive activity named receive_2

Assume you perform the following steps:

  1. Deploy revision 1.0 of composite_A, which includes a BPEL component.

  2. Create an instance of revision 1.0, which is using a correlation set, and input a value of 123, which generates conv_id = "123".

    This process now invokes a web service through a one-way invoke activity and then waits on the receive_2 activity for a callback to arrive.

  3. Deploy revision 2.0 of composite_A, which now becomes the default revision.

    A web service sends a callback for the instance for revision 1.0. However, as a part of its URL, it does not specify the revision number. You typically create a callback so that the URL does not use the revision number. This is because web services are external and you cannot change web service settings to continue using a revision tag because it is internal to Oracle SOA Suite and is a concept that the external world does not understand.

    Since a revision number is not specified, the SOA server assumes that the revision number must be 2.0 and, if the routing of the callback takes the revision number into account, it cannot forward this callback intended for 1.0 to the correct revision 1.0. Instead, it attempts to route it to the default revision 2.0, which does not have any instance waiting for the callback.

    You cannot route callback messages based on revisions. You only receive the option to route callback messages based on the conversion ID (If the correlation set is not used, then even this is not under your control), operation name, and component name.

    For these reasons, different instances must use different conversation IDs (which means different input is used for creating a conversion ID) to avoid confusion, and routing should be solely based on a conversation ID.

9.1.3 What You May Need to Know About Setting Correlations for an IMA Using a fromParts Element With Multiple Parts

Assume you have the following scenario:

  • A BPEL 2.0 process with a WSDL message type that has multiple parts that are identical in type.

  • A property alias has been defined based on the element type of the above part.

For a process that has an inbound message activity (IMA) (for example, a receive activity, onMessage branch of a scope or pick activity, or onEvent branch of a scope activity in BPEL 2.0) that uses the fromParts element with fromPart defined for each part, correlations cannot be defined because the runtime environment cannot determine the part to which to apply the property alias.

For more information about mapping WSDL message parts with the toParts and fromParts elements, see Section 6.17, "Mapping WSDL Message Parts in BPEL 2.0."

9.2 Routing Messages to the Same Instance

Oracle BPEL Process Manager supports a message aggregation feature. When multiple messages are routed to the same process/partner link/operation name, the first message is routed to create a new instance and subsequent messages can be routed to continue the created instance using a midprocess receive activity.

Message aggregation enables you to use the same operation (or event name) in an entry receive activity and a midprocess receive activity.

Notes:

  • This feature only performs aggregation, and not resequencing. This feature does not resequence messages arriving out of order into an ordered format. Therefore, the first message only means the first message processed. This may be different from the first message in a time sequence order.

  • You must use correlation sets to take advantage of the message aggregation feature.

  • Synchronous operations as ambiguous calls (at both beginning and midprocess receive activities) are supported. However, this is not a recommended use of this feature and should be avoided.

9.2.1 How to Configure BPEL Process Instance Creation

You can control the number of instances to create and use to route messages with the reenableAggregationOnComplete property.

To configure BPEL process instance creation:

  1. In the SOA Composite Editor, select the BPEL process service component, as shown in Figure 9-2.

    Figure 9-2 Selected BPEL Process Service Component

    Description of Figure 9-2 follows
    Description of "Figure 9-2 Selected BPEL Process Service Component"

  2. Go to the Property Inspector in the lower right corner of Oracle JDeveloper. If the Property Inspector is not displayed, select Property Inspector from the View main menu.

  3. In the Properties section, click the Add icon, as shown in Figure 9-3.

    Figure 9-3 Property Inspector

    Description of Figure 9-3 follows
    Description of "Figure 9-3 Property Inspector"

    The Create Property dialog is displayed.

  4. In the Name field, enter the bpel.config.reenableAggregationOnComplete deployment descriptor property. The prefix of bpel.config is required for this type of deployment descriptor.

  5. In the Value field, enter true, as described in Table 9-8.

    Table 9-8 reenableAggregationOnComplete Property Settings

    Value Description Example

    true

    Creates a new instance to handle messages. However, there is a window between messages coming in and instance completion. This can result in messages remaining in the DLV_MESSAGE table. This setting can result in the occurrence of race conditions. For more information, see Table 9-9.

    You invoke messages 1 through 4 for a client using the initiate operation. This results in the following actions:

    • Two instances of the BPEL process are created and completed.

    • Messages 1 and 2 are routed to the first instance and messages 3 and 4 are routed to the second instance.

    false

    This is the default behavior. This setting causes the aggregation feature to be disabled. Only one instance is created. Messages that are not handled by the instance remain in the DLV_MESSAGE table. This setting is recommended for most environments.

    You invoke messages 1 through 4 for a client using the initiate operation. One instance of the BPEL process is created and completed.

    You should not attempt to route multiple messages using the same correlation set to one BPEL instance.


    Figure 9-4 shows the completed Create Property dialog.

    Figure 9-4 Create Property Dialog

    Description of Figure 9-4 follows
    Description of "Figure 9-4 Create Property Dialog"

  6. Click OK.

    Example 9-4 shows the reenableAggregationOnComplete property with the bpel.config prefix in the composite.xml file.

    Example 9-4 reenableAggregationOnComplete Property in composite.xml File

    <composite name="Aggregation" revision="1.0" label="2011-07-10_13-52-24_174"
     mode="active" state="on">
    . . .
    . . .
    <component name="Aggregation" version="1.1">
        <implementation.bpel src="Aggregation.bpel"/>
          <property name="bpel.config.reenableAggregationOnComplete" type="xs:string"
                  many="false" override="may">true</property>
      </component>
    . . .
    . . .
    </composite>
    

9.2.2 How to Use the Same Operation in Entry and Midprocess Receive Activities

You create a correlation set as shown in Example 9-5. All messages to Oracle BPEL Process Manager are routed to the same operation name. The messages have the same correlation ID. The interface WSDL does not differentiate between the entry activity (receiveInput) and the midprocess receive activity (Continue_Receive). All messages are processed using the initiate operation. A single instance is created to which to route all messages.

This differs from releases before 11g Release 1 11.1.1.6, in which you needed to define different operation names on the same partner link. The process had to expose two operations and the caller had to choose the correct operation name.

Example 9-5 Correlation with Same Operation in Entry and Midprocess Receive Activities

<receive name="receiveInput" partnerLink="client" portType="client:BPELProcess1"
 operation="initiate" variable="inputVariable" createInstance="yes">
 <correlations>
  <correlation initiate="yes" set="CorrelationSet_1"/>
 </correlations>
</receive>

<!-- Asynchronous callback to the requester. (Note: the callback location and
 correlation id is transparently handled using WS-addressing.) -->
<assign name="Assign_1">
 <copy>
  <from variable="inputVariable" part="payload"
 query="/client:BPELProcess1ProcessRequest/client:input"/>
  <to variable="Invoke_1_initiate_InputVariable" part="payload"
 query="/ns1:BPELProcess2ProcessRequest/ns1:input"/>
 </copy>
</assign>

<receive name="Continue_Receive" partnerLink="client"
 portType="client:BPELProcess1" operation="initiate" variable="inputVariable"
 createInstance="no">
 <correlations>
  <correlation initiate="no" set="CorrelationSet_1"/>
 </correlations>
</receive>

For event delivery network (EDN) business events, you substitute the operation attribute with bpelx:eventName in both the entry and midprocess receive activities.

bpelx:eventName="ns3:initiateEvent"/>

Information is maintained in the DLV_AGGREGATION table:

  • Conversation ID

  • Domain name

  • Component name and type

  • Composite name, label, and revision

  • State

  • Received date

  • CI key

  • Primary key

This information can be deleted from this table with the purge scripts or from the Delete With Options dialog in Oracle Enterprise Manager Fusion Middleware Control. For more information about both of these options, see the Oracle Fusion Middleware Administrator's Guide for Oracle SOA Suite and Oracle Business Process Management Suite.

9.2.3 How to Route a Message to a New or Existing Instance when Using Correlation Sets

For a BPEL process using correlation sets, the correct routing is performed. The message can be either of the following:

  • An invoke message creating a new instance

  • A callback message continuing an existing instance

Figure 9-5 shows entry and midprocess receive activities using the same operation (process).

Figure 9-5 Routing a New Message to a New or Existing Instance

Description of Figure 9-5 follows
Description of "Figure 9-5 Routing a New Message to a New or Existing Instance"

Example 9-6 provides an example the entry and midprocess receive activities using the same operation (process).

Example 9-6 Routing a New Message to a New or Existing Instance

<receive name="receiveInput" partnerLink="client" portType="client:BPELProcess1"
 operation="process" variable="inputVariable" createInstance="yes">
 <correlations>
  <correlation initiate="yes" set="CorrelationSet_1"/>
 </correlations>
</receive>

<!-- some business logic -->

<while name="While_1" condition=*loop for 3 iterations*>
 <sequence name="Sequence_1">
  <receive name="Continue_Receive" partnerLink="client"
 portType="client:BPELProcess1" operation="process" variable="inputVariable"
 createInstance="no">
   <correlations>
    <correlation initiate="no" set="CorrelationSet_1"/>
   </correlations>
  </receive>

<!-- some business logic -->

 </sequence>
</while>

In the initial scenario in Example 9-6, the following actions occur in BPEL process P1:

  • A partner provides four messages (message 1, message 2, message 3, and message 4) for the same partner (correlation ID 101).

  • Message 1 creates a new instance of BPEL process P1. This message is marked as an invoke message.

  • Messages 2, 3, and 4 are received using the Continue_Receive activity. These messages are marked as callback messages.

  • The instance closes because three iterations of the while loop are expected.

Assume now that additional messages are routed, which can potentially cause race conditions to occur. Table 9-9 provides details.

Table 9-9 Message Delivery Scenarios

Scenario Description Marked as Invoke Message Marked as Callback Message

1

Assume the partner now provides message 5 for the same correlation ID (101). Message 5 creates a new instance of BPEL process P1 and waits on the Continue_Receive activity inside the while loop for three more messages (6, 7, and 8).

  • Message 1

  • Message 5

  • Message 2

  • Message 3

  • Message 4

  • Message 6

  • Message 7

  • Message 8

2

If messages 4 and 5 are received within a small time window, it is possible that message 4 is closing the instance BPEL process P1 and message 5 is routed as a callback to that instance. This scenario can cause a race condition. For example:

  • When message 6 arrives, it is routed to the entry receive activity of the new instance.

  • Messages 7 and 8 are routed to the Continue_Receive activity.

  • Message 5 is routed to the Continue_Receive activity only by the recovery part of the BPEL process service engine. This is because it initially was routed to a closed instance and could not be handled.

  • Message 1

  • Message 6

  • Message 2

  • Message 3

  • Message 4

  • Message 5

  • Message 7

  • Message 8

3

This is similar to scenario 2. However, in this case, messages 7, 8, and 9 are not received. For example:

  • Message 5 becomes an unhandled callback message waiting for a subscriber.

  • BPEL process service engine recovery tries to process message 5 and fails because there is no subscriber available.

There are several options for message recovery.

  • Limit recovery of callback messages with the System MBean Browser property maxRecoverAttempt in Oracle Enterprise Manager Fusion Middleware Control. This count specifies the number of attempts made by automatic recovery to recover an invoke/callback message. Once the number of recover attempts exceeds this count, the state of the message is changed to exhausted. For more information, see Section "Configuring Automatic Recovery Attempts for Invoke and Callback Messages" in Oracle Fusion Middleware Administrator's Guide for Oracle SOA Suite and Oracle Business Process Management Suite.

  • Write a custom SQL script to check that the criteriaCallback has state set to 0. The correlation value for this callback exists in CORRELATION_GROUP in a closed state (state = 0). This indicates that the callback message is marked for a closed aggregation instance. You can cancel/purge these instances based on business logic.

    Note: BPEL is designed as a conversation-based system. At any point in which unsolicited messages are not being handled, the application is always aware of the messages coming as part of correlation aggregation and chooses to subscribe and process or ignore the message as required by business needs.

  • Message 1

  • Message 6

  • Message 2

  • Message 3

  • Message 4

  • Message 5