Introduction to Oracle BPEL Process Manager Sensors
Sensors are used to declare interest in specific events throughout the life cycle of a BPEL process instance. In a business process, that can be the activation and completion of a specific activity or the modification of a variable value in the business process.
When a sensor is triggered, a specific sensor value is created. For example, if a sensor declares interest in the completion of a BPEL scope, the sensor value consists of the name of the BPEL scope and a time stamp value of when the activity was completed. If a sensor value declares interest in a BPEL process variable, then the sensor value consists of the following:
-
The value of the variable at the moment it was modified
-
A time stamp when the variable was modified
-
The activity name and type that modified the BPEL variable
The data format for sensor values is normalized and well-defined using XML schema.
A sensor action is an instruction on how to process sensor values. When a sensor is triggered by Oracle BPEL Process Manager, a new sensor value for that sensor is created. After that, all the sensor actions associated with that sensor are performed. A sensor action typically persists the sensor value in a database or sends the normalized sensor value data to a JMS queue or topic. For integration with Oracle BAM, the sensor value can be sent to the Oracle BAM adapter.
You can define the following types of sensors, either through Oracle JDeveloper or manually by providing sensor configuration files.
-
Activity sensors
Activity sensors monitor the execution of activities within a BPEL process. For example, they can monitor the execution time of an invoke activity or how long it takes to complete a scope. Along with the activity sensor, you can also monitor variables of the activity.
-
Variable sensors
Variable sensors are used to monitor variables (or parts of a variable) of a BPEL process. For example, variable sensors can monitor the input and output data of a BPEL process.
-
Fault sensors
Fault sensors are used to monitor BPEL faults.
You typically add or edit sensors as part of the BPEL modeling of activities, faults, and variables.
These sensors are exposed through the following public SQL views:
-
BPEL_ACTIVITY_SENSOR_VALUES
-
BPEL_FAULT_SENSOR_VALUES
-
BPEL_VARIABLE_SENSOR_VALUES
These views can be joined with the BPEL_PROCESS_INSTANCES
view to associate the sensor value with the BPEL process instance that created the sensor values. For more information, see Understanding Sensor Public Views and the Sensor Actions XSD.
When you model sensors in Oracle JDeveloper, two new files are created as part of the BPEL process archive:
-
bpel_process_name
_
sensor.xml
Contains the sensor definitions of a BPEL process
-
bpel_process_name
_
sensorAction.xml
Contains the sensor action definitions of a BPEL process
For information about how these files are created, see How to Configure Activity, Variable, and Fault Sensors and How to Configure Sensor Actions.
After you define sensors for a BPEL process, you must configure sensor actions to publish the sensor data to a specified destination. If no sensor action is defined for a sensor, then nothing happens at runtime.
The following information is required for a sensor action:
-
Name
-
Publish type
The publish type specifies the destination in which the sensor data must be presented. You can publish sensor data to the following destination types.
-
Database
Publishes the sensor data to the reports schema in the database. The sensor data can then be queried using SQL.
-
JMS queue
Publishes the sensor data to a JMS queue. The XML data is posted in accordance with the
Sensor.xsd
file. This file is included with Oracle JDeveloper in the following directory:/soa/integration/seed/soa/shared/bpel/Sensor.xsd
The
Sensor.xsd
file is also included in the following directory:/soa/integration/jdeveloper/seed/soa/shared/bpel/Sensor.xsd
-
JMS topic
Publishes the sensor data to a JMS topic. The XML data is posted in accordance with the same
Sensor.xsd
file used with JMS queues. -
Custom
Publishes the data to a custom Java class.
-
JMS Adapter
Uses the JMS adapter to publish to remote queues or topics and a variety of different JMS providers. The JMS queue and JMS topic publish types only publish to local JMS destinations.
-
-
List of sensors
The sensors for a sensor action.