Ce contenu n'est pas disponible dans la langue sélectionnée.
Chapter 18. Persistence
Binary persistence, or marshaling, converts the state of the process instance into a binary data set. Binary persistence is a mechanism used to store and retrieve information persistently. The same mechanism is also applied to the session state and work item states.
When you enable persistence of a process instance:
- Red Hat Process Automation Manager transforms the process instance information into binary data. Custom serialization is used instead of Java serialization for performance reasons.
- The binary data is stored together with other process instance metadata, such as process instance ID, process ID, and the process start date.
The session can also store other forms of state, such as the state of timer jobs, or data required for business rules evaluation. Session state is stored separately as a binary data set along with the ID of the session and metadata. You can restore the session state by reloading a session with given ID. Use ksession.getId()
to get the session ID.
Red Hat Process Automation Manager will persist the following when persistence is configured:
- Session state: This includes the session ID, date of last modification, the session data that business rules would need for evaluation, state of timer jobs.
- Process instance state: This includes the process instance ID, process ID, date of last modification, date of last read access, process instance start date, runtime data (the execution status including the node being executed, variable values, and other process instance data) and the event types.
- Work item runtime state: This includes the work item ID, creation date, name, process instance ID, and the work item state itself.
Based on the persisted data, you can restore the state of execution of all running process instances in case of failure or to temporarily remove running instances from memory and restore them later.
18.1. Configuring Process Server persistence Copier lienLien copié sur presse-papiers!
You can configure the Process Server persistence by passing Hibernate or JPA parameters as system properties.
The Process Server can acknowledge the system properties with the following prefixes and you can use every Hibernate or JPA parameters with these prefixes:
-
javax.persistence
-
hibernate
Procedure
To configure Process Server persistence, complete any of the following tasks:
If you want to configure Process Server persistence using Red Hat JBoss EAP configuration file, complete the following tasks:
-
In your Red Hat Process Automation Manager installation directory, navigate to the
standalone-full.xml
file. For example, if you use Red Hat JBoss EAP installation for Red Hat Process Automation Manager, go to$EAP_HOME/standalone/configuration/standalone-full.xml
file. Open the
standalone-full.xml
file and under the<system-properties>
tag, set your Hibernate or JPA parameters as system properties.Example of configuring Process Server persistence using Hibernate parameters
<system-properties> ... <property name="hibernate.hbm2ddl.auto" value="create-drop"/> ... <system-properties>
<system-properties> ... <property name="hibernate.hbm2ddl.auto" value="create-drop"/> ... <system-properties>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Example of configuring Process Server persistence using JPA parameters
<system-properties> ... <property name="javax.persistence.jdbc.url" value="jdbc:mysql://mysql.db.server:3306/my_database?useSSL=false&serverTimezone=UTC"/> ... <system-properties>
<system-properties> ... <property name="javax.persistence.jdbc.url" value="jdbc:mysql://mysql.db.server:3306/my_database?useSSL=false&serverTimezone=UTC"/> ... <system-properties>
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
If you want to configure Process Server persistence using command line, complete the following tasks:
Pass the parameters directly from the command line using
-Dkey=value
as follows:Example of configuring Process Server persistence using Hibernate parameters:
$EAP_HOME/bin/standalone.sh -Dhibernate.hbm2ddl.auto=create-drop
$EAP_HOME/bin/standalone.sh -Dhibernate.hbm2ddl.auto=create-drop
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Example of configuring Process Server persistence using JPA parameters:
$EAP_HOME/bin/standalone.sh -Djavax.persistence.jdbc.url=jdbc:mysql://mysql.db.server:3306/my_database?useSSL=false&serverTimezone=UTC
$EAP_HOME/bin/standalone.sh -Djavax.persistence.jdbc.url=jdbc:mysql://mysql.db.server:3306/my_database?useSSL=false&serverTimezone=UTC
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
-
In your Red Hat Process Automation Manager installation directory, navigate to the
18.2. Configuring safe points Copier lienLien copié sur presse-papiers!
To allow persistence, add the jbpm-persistence
JAR files to the classpath of your application and configure the process engine to use persistence. The process engine automatically stores the runtime state in the storage when the process engine reaches a safe point.
Safe points are points where the process instance has paused. When a process instance invocation reaches a safe point in the process engine, the process engine stores any changes to the process instance as a snapshot of the process runtime data. However, when a process instance is completed, the persisted snapshot of process instance runtime data is automatically deleted.
If a failure occurs and you need to restore the process engine runtime from the storage, the process instances are automatically restored and their execution resumes so there is no need to reload and trigger the process instances manually.
The runtime persistence data is to be considered internal to the process engine. You should not access persisted runtime data or modify them directly as this might have unexpected side effects.
For more information about the current execution state, refer to the history log. Query the database for runtime data only if absolutely necessary.
18.3. Session persistence entities Copier lienLien copié sur presse-papiers!
Sessions are persisted as SessionInfo
entities. These persist the state of the runtime KIE session, and store the following data:
Field | Description | Nullable |
---|---|---|
| The primary key. | NOT NULL |
| The last time that entity was saved to a database. | |
| The state of a session. | NOT NULL |
| The session start time. | |
| A version field containing a lock value. |
18.4. Process instance persistence entities Copier lienLien copié sur presse-papiers!
Process instances are persisted as ProcessInstanceInfo
entities, which persist the state of a process instance on runtime and store the following data:
Field | Description | Nullable |
---|---|---|
| The primary key. | NOT NULL |
| The last time that the entity was saved to a database. | |
| The last time that the entity was retrieved from the database. | |
| The ID of the process. | |
| The state of a process instance in form of a binary data set. | NOT NULL |
| The start time of the process. | |
| An integer representing the state of a process instance. | NOT NULL |
| A version field containing a lock value. |
ProcessInstanceInfo
has a 1:N relationship to the EventTypes
entity.
The EventTypes
entity contains the following data:
Field | Description | Nullable |
---|---|---|
|
A reference to the | NOT NULL |
| A finished event in the process. |
18.5. Work item persistence entities Copier lienLien copié sur presse-papiers!
Work items are persisted as workiteminfo
entities, which persist the state of the particular work item instance on runtime and store the following data:
Field | Description | Nullable |
---|---|---|
| The primary key. | NOT NULL |
| The name of the work item. | |
| The (primary key) ID of the process. There is no foreign key constraint on this field. | NOT NULL |
| The state of a work item. | NOT NULL |
| A version field containing a lock value. | |
| The work item state in as a binary data set. | NOT NULL |
18.6. Correlation key entities Copier lienLien copié sur presse-papiers!
The CorrelationKeyInfo
entity contains information about the correlation key assigned to the given process instance. This table is optional. Use it only when you require correlation capabilities.
Field | Description | Nullable |
---|---|---|
| The primary key. | NOT NULL |
| The assigned name of the correlation key. | |
| The ID of the process instance which is assigned to the correlation key. | NOT NULL |
| A version field containing a lock value. |
The CorrelationPropertyInfo
entity contains information about correlation properties for a correlation key assigned the process instance.
Field | Description | Nullable |
---|---|---|
| The primary key. | NOT NULL |
| The name of the property. | |
| The value of the property. | NOT NULL |
| A version field containing a lock value. | |
| A foreign key mapped to the correlation key. | NOT NULL |
18.7. Context mapping entity Copier lienLien copié sur presse-papiers!
The ContextMappingInfo
entity contains information about the contextual information mapped to a KieSession
. This is an internal part of RuntimeManager
and can be considered optional when RuntimeManager
is not used.
Field | Description | Nullable |
---|---|---|
| The primary key. | NOT NULL |
| The context identifier. | NOT NULL |
|
The | NOT NULL |
| A version field containing a lock value. | |
| Holds the identifier of the deployment unit that the given mapping is associated with |
18.8. Pessimistic Locking Support Copier lienLien copié sur presse-papiers!
The default locking mechanism for persistence of processes is optimistic. With multi-thread high concurrency to the same process instance, this locking strategy can result in bad performance.
This can be changed at runtime to allow the user to set locking on a per process basis and to allow it to be pessimistic (the change can be made at a per KIE Session level or Runtime Manager level as well and not just at the process level).
To set a process to use pessimistic locking, use the following configuration in the runtime environment: