53 Defining Composite Sensors
This chapter includes the following sections:
For information about activity, fault, and variable sensors in a BPEL process, see Using Sensors and Analytics .
For examples of using composite sensors in business scenarios, see Understanding Oracle SOA Suite.
53.1 Introduction to Composite Sensors
Composite sensors provide a method for implementing trackable fields on messages. Composite sensors enable you to perform the following tasks:
- 
                        Monitor incoming and outgoing messages. 
- 
                        Specify composite sensor details in the search utility of the Flow Instances pages for the SOA Infrastructure, partition, and SOA composite application in Oracle Enterprise Manager Fusion Middleware Control. This action enables you to display details about a particular instance with a composite sensor. 
- 
                        Publish JMS data computed from incoming and outgoing messages. 
- 
                        Track composite instances initiated through business event subscriptions. 
You define composite sensors on service and reference binding components or on service components that have business event subscriptions in Oracle JDeveloper. This functionality is similar to variable sensors in BPEL processes. During runtime, composite sensor data is persisted in the database.
You can also define composite sensors during runtime in Oracle SOA Composer. Oracle SOA Composer changes are picked up immediately by the runtime, whereas changes made using Oracle JDeveloper require SOA composite application redeployment.
For information about searching for composite sensors in Oracle Enterprise Manager Fusion Middleware Control, see Section "Tracking Business Flow Instances at the SOA Infrastructure or Partition Level" of Administering Oracle SOA Suite and Oracle Business Process Management Suite.
53.1.1 Restrictions on Use of Composite Sensors
Note the following restrictions on the use of composite sensors:
- 
                           Functions in XPath expressions cannot be used with properties. 
- 
                           Any composite sensor that is defined by an expression always captures values as strings. This causes the sensor type to always be a string. This action makes the search possible. Capturing values as strings may be useful when dealing with XML types derived from a string. The following example provides details: <xs:element name="CardNum"> <xs:simpleType> <xs:restriction base="xs:string"> <xs:length value="16"/> </xs:restriction> </xs:simpleType> </xs:element>Even if the expression is a number, it is captured as a string. You cannot use other logical operators such as <,>,=, or any combination of these.
- 
                           Any composite sensor that is defined by a variable uses the variable type to determine the sensor type. Sensors can be one of the following types: - 
                                 STRING
- 
                                 NUMBER
- 
                                 DATE
- 
                                 DATE_TIME
- 
                                 Complex XML 
 
- 
                                 
- 
                           Composite sensors only support two types of sensor actions: Enterprise Manager and JMS. 
- 
                           Header-based sensors are only supported for web service bindings. 
- 
                           Sensor actions for Oracle B2B, service data objects (SDOs), web services invocation framework (WSIF), and Oracle Business Activity Monitoring bindings are not supported. 
- 
                           When creating an XPath expression for filtering, all functions that return a node set must be explicitly cast as a string: xpath20:upper-case(string($in.request/inp1:updateOrderStatus/inp1:orderStatus) ) = "PENDING"
- 
                           Sensors cannot be configured on service components that publish business events. 
- 
                           Sensors based on business event headers are not allowed (only payloads are allowed). 
- 
                           PL/SQL subscriptions are not supported. 
53.2 Adding Composite Sensors
You add sensors to the following components of a SOA composite application in the SOA Composite Editor:
- 
                        Service or reference binding components 
- 
                        Service components such as a BPEL process or Oracle Mediator that have subscribed to business events 
53.2.1 How to Add Composite Sensors
To add composite sensors:
- 
                              Use one of the following options to add a composite sensor in the SOA Composite Editor: - Option 1:
                                    - 
                                          
                                          Right-click a specific service or reference binding component in the Exposed Services or External References swimlane or a service component that has a subscribed business event. A service component that has a subscribed business event includes the word Subscribed on it. 
- 
                                          
                                          Select Configure Sensors. Note: The service component must already have a subscribed business event for the Configure Sensors option to be displayed. If you selected a binding component, the Composite Sensors dialog displays the details shown in Figure 53-1. For this example, a service binding component is selected. Figure 53-1 Composite Sensors Dialog for the Selected Binding Component  
 Description of "Figure 53-1 Composite Sensors Dialog for the Selected Binding Component"If you selected a service component, the Composite Sensors dialog displays the details shown in Figure 53-2. Figure 53-2 Composite Sensors Dialog for the Selected Service Component  
 Description of "Figure 53-2 Composite Sensors Dialog for the Selected Service Component"
- 
                                          
                                          Select the binding component or service component in the dialog, and click the Add icon. 
 
- 
                                          
                                          
- Option 2:
                                    - 
                                          
                                          Click the Composite Sensor icon above the SOA Composite Editor, as shown in Figure 53-3. The Composite Sensors dialog for the SOA composite application appears, as shown in Figure 53-4. This option displays all the service and reference binding components and service components with subscribed business events in the SOA composite application. 
- 
                                          
                                          Select the specific service, reference, or business event to which to add a composite sensor, then click the Add icon. 
 
- 
                                          
                                          
 If you selected a binding component such as a service, the Create Composite Sensor dialog appears as shown in Figure 53-5. Figure 53-5 Create Composite Sensor Dialog for a Service Binding Component  
 Description of "Figure 53-5 Create Composite Sensor Dialog for a Service Binding Component"If you selected a service component that has a business event subscription, the Create Composite Sensor dialog appears as shown in Figure 53-6. Figure 53-6 Create Composite Sensor Dialog for a Service Component  
 Description of "Figure 53-6 Create Composite Sensor Dialog for a Service Component"
- Option 1:
                                    
- 
                              Enter the details shown in Table 53-1. Table 53-1 Create Composite Sensor Dialog Name Description Name Enter a name for the composite sensor. You must enter a name to enable the Edit icon of the Expression field. Service Displays the name of the service. This field is only displayed if you are creating a composite sensor for a service binding component. This field cannot be edited. Service sensors monitor the messages that the service receives from the external world or from another composite application. Reference Displays the name of the reference. This field is only displayed if you are creating a composite sensor for a reference binding component. This field cannot be edited. Reference sensors monitor the messages that the reference sends to the external world or to another composite application. Operation Select the operation for the port type of the service or reference. This field only displays for service or reference binding components. Event Displays the name of the service component. This field is only displayed if you are creating a composite sensor for a service component. This field cannot be edited. Event sensors track composite instances initiated through a business event. You can create multiple sensors per business event. Event Type Displays the Subscribe business event type. This field cannot be edited. The publish business event type is not supported. Expression Click the Edit icon to display a dropdown list for selecting the type of expression to create: - 
                                                   Variables: Select to create an expression value for a variable. See How to Add a Variable. 
- 
                                                   Expression: Select to open the Expression Builder dialog for creating an XPath expression. This action always captures values as strings. See How to Add an Expression. 
- 
                                                   Properties: Select to create an expression value for a normalized message header property. These are the same properties that display under the Properties tab of the invoke activity, receive activity, reply activity, OnEvent branch of a scope activity (in BPEL 2.0), and OnMessage branch of a pick activity and scope activity (in BPEL 2.0). See How to Add a Property. 
 Filter Click the Edit icon to open the Expression Builder dialog to create an XPath filter for the expression. You must first create an expression to enable this field. For example, you may create an expression for tracking purchase order amounts over 10,000:$in.inDict/tns:inDict/ns2:KeyValueOfstringstring/ns2:Value > 10000.00 Composite Sensor Actions Displays the supported sensor actions. This feature enables you to store runtime sensor data. You can select both Enterprise Manager and either JMS Queue or JMS Topic. - 
                                                   Enterprise Manager Select to make runtime sensor data searchable in the Flow Instances tab of a SOA composite application in Oracle Enterprise Manager Fusion Middleware Control. This selection is the same as the DBSensorAction selection of previous releases. Note: When Enterprise Manager is selected, sensor data is sent to the trackable fields tables. When it is not selected, data is not sent. However, in both cases, Oracle Enterprise Manager Fusion Middleware Control still displays the fields that enable you to search for composite instances based on that sensor. For more information, see Administering Oracle SOA Suite and Oracle Business Process Management Suite. 
- 
                                                   JMS Queue Select to store composite sensor data (XML payload) in a JMS queue. You must specify the JMS connection factory and queue name. 
- 
                                                   JMS Topic Select to store composite sensor data (XML payload) in a JMS topic. You must specify the JMS connection factory and topic name. 
 Notes: The JMS Queue and JMS Topic selections enable the composite sensor data (XML payload) to be used by other consumers, including Oracle Business Activity Monitoring (BAM) and Oracle Complex Event Processing. Both selections use the native JMS support provided with Oracle WebLogic Server, and not the Oracle SOA Suite JMS adapter described in Understanding Technology Adapters. You can view JMS messages in the Oracle WebLogic Server Administration Console. 
- 
                                                   
- 
                              Click OK. For a service or reference binding component, a composite sensor icon displays in the upper right corner, as shown in Figure 53-7. Figure 53-7 Sensor Icon on Binding Component  
 Description of "Figure 53-7 Sensor Icon on Binding Component"For a service component, a composite sensor icon also displays in the upper right corner, as shown in Figure 53-8. Figure 53-8 Sensor Icon on Service Component  
 Description of "Figure 53-8 Sensor Icon on Service Component"
- 
                              Place your cursor over the composite sensor icon to display details about the composite sensor. 
53.2.1.1 How to Add a Variable
The Select XPath Expression dialog shown in Figure 53-9 enables you to select an element for tracking.
To add a variable:
53.2.1.2 How to Add an Expression
The Expression Builder dialog shown in Figure 53-10 enables you to create an expression for tracking.
For more information, see Building XPath Expressions in the Expression Builder in Oracle JDeveloper.
To add an expression:
Note:
For variables, Expression Builder inserts$in/variablename. If you are using payload arguments in your
                expression, you must manually update this syntax to
                        $in.payload/variablename. For example:
                        
                              concat($in.payload/element, '_',
                    $in.payload/element2)
53.2.1.3 How to Add a Property
The Select Property dialog shown in Figure 53-11 enables you to select a normalized message header property for tracking.
To add a property:
For more information about normalized messages, see Propagating Normalized Message Properties Through Message Headers.
53.2.2 What You May Need to Know About Duplicate Composite Sensor Names
Note the following details when using duplicate names for composite sensors.
- 
                           If you create composite sensors with duplicate names, the entire contents of their definitions are compared. Duplicate names are permitted where one or more additional parameters are different (for example, either different configuration types or different expressions, filters, operation names, and so on). Something must be different in the definitions for duplicate names to be permitted. 
- 
                           If you have duplicate sensor definitions, only the last executed sensor value is persisted. Therefore, you can use this type of configuration for mutually exclusive paths (for example, a composite can be invoked through service 1 or service 2). Therefore, you can define the same sensor name on both the services. However, if you define the same names for service 1 and reference 1, only the sensor value from reference 1 (the last executed sensor) is stored. 
- 
                           You typically use multiple sensors with the same name to point to the same logical entity extracted from different sources (for example, Oracle Enterprise Manager Fusion Middleware Control displays the final sensor value). Therefore, it can be confusing if the same sensor name is used to extract an email value and a social security value from different sources. 
- 
                           Sensor actions apply to all occurrences of the same sensor name. This situation means the sensor actions on the most recently defined sensor with the same name take precedence. 
For the scenario shown in sensor.xml in the following example:
                     
- 
                           The first two sensors named Service1are identical. In addition, the configuration type for both isserviceConfig(composite sensors defined on a service binding component). Therefore, the sensors become one entry (the second one is ignored).
- 
                           The third sensor named Service1has a different configuration type ofeventConfig(a composite sensor defined on a business event). Therefore, this sensor is represented with a separate entry.
- 
                           The two sensors named PurchaseOrderIdhave different configuration types (eventConfigandserviceConfig). Therefore, they are represented with separate entries.
- 
                           The two sensors named PurchaseOrderhave the same configuration type (eventConfig), but different expressions. Therefore, they are represented with separate entries.
<sensors xmlns="http://xmlns.oracle.com/bpel/sensor"> <sensor sensorName="Service1" kind="service" target="undefined" filter=""> <serviceConfig service="OrderPublisher_ep" expression="$in.property.tracking.ecid" operation="execute" outputDataType="string" outputNamespace="http://www.w3.org/2001/XMLSchema"/> </sensor> <sensor sensorName="Service1" kind="service" target="undefined" filter=""> <serviceConfig service="OrderPublisher_ep" expression="$in.property.tracking.ecid" operation="execute" outputDataType="string" outputNamespace="http://www.w3.org/2001/XMLSchema"/> </sensor> <sensor sensorName="Service1" kind="event" target="undefined" filter="" xmlns:po="http://www.mycompany.com/ns/order"> <eventConfig component="EventMediator" expression="$in/po:PurchaseOrder/po:OrderID" event="{http://mycompany.com/events/orders}OrderReceivedEvent" outputDataType="string" outputNamespace="http://www.w3.org/2001/XMLSchema"/> <sensor sensorName="Event1" kind="event" target="undefined" filter=""> <eventConfig component="EventMediator" actionType="Subscribe" expression="$in.property.tracking.ecid" event="{http://mycompany.com/events/orders}OrderReceivedEvent" outputDataType="string" outputNamespace="http://www.w3.org/2001/XMLSchema"/> </sensor> <sensor sensorName="PurchaseOrder Id" kind="event" target="undefined" filter="" xmlns:po="http://www.mycompany.com/ns/order"> <eventConfig component="EventMediator" expression="$in/po:PurchaseOrder/po:OrderID" event="{http://mycompany.com/events/orders}OrderReceivedEvent" outputDataType="string" outputNamespace="http://www.w3.org/2001/XMLSchema"/> </sensor> <sensor sensorName="PurchaseOrder Id" kind="service" target="undefined" filter=""> <serviceConfig service="OrderPublisher_ep" expression="$in.property.tracking.ecid" operation="execute" outputDataType="string" outputNamespace="http://www.w3.org/2001/XMLSchema"/> </sensor> <sensor sensorName="PurchaseOrder" kind="event" target="undefined" filter="" xmlns:po="http://www.mycompany.com/ns/order"> <eventConfig component="EventMediator" expression="$in/po:PurchaseOrder" event="{http://mycompany.com/events/orders}OrderReceivedEvent" outputDataType="PurchaseOrder" outputNamespace="http://mycompany.com/events/orders"/> </sensor> <sensor sensorName="PurchaseOrder" kind="event" target="undefined" filter="" xmlns:po="http://www.mycompany.com/ns/order"> <eventConfig component="EventMediator" expression="$in/po:PurchaseOrder/po:OrderID" event="{http://mycompany.com/events/orders}OrderReceivedEvent" outputDataType="string" outputNamespace="http://www.w3.org/2001/XMLSchema"/> </sensor> </sensor> </sensors>
53.3 Monitoring Composite Sensor Data During Runtime
During runtime, composite sensor data can be monitored in Oracle Enterprise Manager Fusion Middleware Control:
- 
                        Composite sensor data displays in the flow trace of a SOA composite application. 
- 
                        Composite sensor data can be searched for on the Flow Instances page at the SOA Infrastructure, individual partition, and SOA composite application levels. 
For more information about searching for composite sensors in Oracle Enterprise Manager Fusion Middleware Control, see Section "Monitoring and Deleting SOA Composite Application Instances at the SOA Infrastructure Level" and Section "Monitoring and Deleting SOA Composite Application Instances from the Application Home Page" of Administering Oracle SOA Suite and Oracle Business Process Management Suite.
53.4 Creating and Managing Composite Sensors During Runtime from Oracle SOA Composer
You can create, update, and delete composite sensors during runtime from Oracle SOA Composer without having to redeploy a SOA composite application. The following example describes how to create a composite sensor. Changes to composite sensors can be carried to new revisions of the composite through patching.
Ensure that you understand the issues around using duplicate names for composite sensors. For more information, see What You May Need to Know About Duplicate Composite Sensor Names.
To create and manage composite sensors during runtime from Oracle SOA Composer:












