This chapter includes the following sections:
Deleting Large Numbers of Flow Instances_ Adapter Reports_ and Fault Alerts
Removing Records from the Runtime Tables Without Dropping the Tables
Note:
Table partitioning is an advanced database task and must only be performed by an experienced database administrator (DBA).
For additional information about troubleshooting database growth issues, see Parallel Purging and Table Partitioning Issues, Extending Tablespaces to Avoid Problems at Runtime, and Resolving Database Growth Issues Caused by a High Volume of Transactions.
For information about database growth management strategies, see Developing a Database Growth Management Strategy .
When the amount of data in the Oracle SOA Suite database grows very large, maintaining the database can become difficult. To address this challenge, several methods for managing database growth are provided, as described in Table 13-1.
Table 13-1 Database Growth Strategies
| Environment | Use | See Section | 
|---|---|---|
| Small development installations with more than 100K rows in the database | Auto Purge page of Oracle Enterprise Manager Fusion Middleware Control or the looped purge script | Deleting Large Numbers of Instances with or | 
| Medium installations that generate less than 10 GB of data per day and retain less than 500 GB of data | Auto Purge page of Oracle Enterprise Manager Fusion Middleware Control or a scheduled parallel purge with optimal thread count | Deleting Large Numbers of Instances with or | 
| Large installations that generate more than 10 GB of data per day or retain more than 500 GB of data | 
 | Deleting Large Numbers of Flow Instances_ Adapter Reports_ and Fault Alerts | 
| 
 | Truncate scripts | Removing Records from the Runtime Tables Without Dropping the Tables | 
This section summarizes the main points into an action plan that you can follow to purge and partition the dehydration store. Purging is an essential part of any plan and should be performed when data is consuming too much space or you have some other reason for removing the data.
There are three main strategies for reducing the size of the schemas:
Purge script, which can be executed through either of the following methods:
Automatically from the Auto Purge page in Oracle Enterprise Manager Fusion Middleware Control
Manually in SQL*Plus
Purge script + partitioning (or, more correctly, dropping table partitions)
Partitioning all tables
The purge script uses standard SQL DELETE statements to remove rows from the BPEL tables. For most sites, this is sufficient. However, some sites accumulate so much data that the purge script takes too long to run. In this case, partitioning becomes the better solution. The trade off is that partitioning involves significantly more database maintenance. Moreover, partitioning is an advanced technique and requires a knowledgeable and skilled DBA. By contrast, running the purge script is straightforward and does not require significant DBA knowledge.
Try to profile the input messages, database growth rate, and how much data is purged in the purge process. If the input rate and purge rate match, then regular purging is sufficient. Otherwise, consider partitioning.
If you use partitioning, Oracle recommends that you add disk space and eventually drop the partition. However, this creates additional requirements for managing disk capacity, deciding on the correct partition size, and so on. Do not use partitioning and then rely on the purge script to reclaim disk space.
You can delete flow instances, adapter reports, and fault alerts with the purge scripts (invoked either automatically from the Auto Purge page in Oracle Enterprise Manager Fusion Middleware Control or manually in SQL*Plus).
Note the following details:
The purge scripts delete instances that have completed or are in error (have faulted). For more information, see Purge States.
The purge scripts do not delete instances that are in-flight or can be recovered (are in a recovery required state).
The purge scripts delete all Oracle SOA Suite-related tables except for Oracle B2B. If you have an installation in which Oracle SOA Suite and Oracle B2B are co-located, ensure that you also invoke the Oracle B2B purge scripts. If you have separate Oracle SOA Suite and Oracle B2B installations, you must run only the appropriate purge scripts on the respective product schemas. For information about purging Oracle B2B, see Chapter "Purging Data" and Chapter "B2B Command-Line Tools" of the User's Guide for Oracle B2B.
Beginning with 12c (12.1.3), Oracle Enterprise Manager Fusion Middleware Control and the purge scripts delete the MEDIATOR_RESEQUENCER_MESSAGE and MEDIATOR_GROUP_STATUS tables.
Installers must configure the database scheduler timezone properly or the purge job may run at unexpected times.
You can delete the following tables by running the purge scripts from SQL*Plus or from the Auto Purge page in Oracle Enterprise Manager Fusion Middleware Control:
MEDIATOR_GROUP_STATUS
EIS_CONNECTION_DOWN_TIME and MESSAGE_STATISTICS (JCA adapter reports).
FAULT_ALERT
Group information for resequencing groups is not deleted. Groups contain the necessary information about the next sequence ID for that group. Purging this information is the same as starting the group from the initial sequence ID, which may not be your intent.
The following sections describe how to invoke the purge scripts from the Auto Purge page in Oracle Enterprise Manager Fusion Middleware Control or from SQL*Plus to delete flow instances, adapter reports, and fault alerts:
Note:
There is no purge script support on the IBM DB2 database.
Instances in the following states are purged with the Oracle Enterprise Manager Fusion Middleware Control or the purge scripts:
Completed successfully
Faulted
Terminated by user
Aborted
Unknown (instance tracking is disabled)
Purging of the following instance states is not supported:
Instances pending recovery at the BPEL process service engine level or SOA composite application level
Running instances
To purge these instances, you must first move them to one of the instance states supported by the purge scripts.
Use the Auto Purge page in Oracle Enterprise Manager Fusion Middleware Control to schedule and execute jobs that automatically remove older flow instances, adapter reports, and fault alerts data from the database.
Note:
Oracle recommends that you enable automatic purging on the Auto Purge page to optimize runtime environment performance. The status of automatic purging is displayed in the Key Configuration section of the Dashboard page at the SOA Infrastructure and individual partition levels. Automatic purging is automatically enabled for new 12c installations, but not for upgraded environments.
Ensure that you back up important data before enabling or changing purge configurations.
The Auto Purge page is not available if you are using the Java database included with the SOA Developer Install option. Use the truncate_soa_javadb.sql script to purge the database.
Access this page through one of the following options:
| From the SOA Infrastructure Menu... | From the SOA Folder in the Navigator... | From the Key Configuration Section of the Dashboard Page... | From the Key Configuration Section of the Dashboard Page... | 
|---|---|---|---|
| 
 | 
 | 
 | 
 | 
The Auto Purge page is displayed.
Select values appropriate to your environment, and click Apply.
| Field | Description | 
|---|---|
| Auto Purge Job | Select the predefined database purge jobs to run. You cannot add jobs. For example; you can select the following: 
 Warning: When you enable or disable an auto purge job, you must save or revert your changes before selecting a different job or navigating away from this page. Otherwise, any unsaved changes made to the currently selected job are lost. | 
| Enabled | Select to enable automatic database purging with the database purge job selected from the Auto Purge Job list. The purge interval begins when it is enabled. For example, If you specify seven days in the Retain Data field, data is retained from the day you re-enabled this checkbox. Newer data is retained for seven days from when it was created. | 
| Calendaring Expression icon | Click to view examples of job scheduling syntax. Copy and paste the syntax appropriate to your environment into the Job Schedule field and modify as necessary. Click More Info to access documentation about how to configure job frequency by setting the  | 
| Job Schedule | Specify a job execution schedule to purge instances. The default schedule is to perform a daily purge at midnight. This is a required field. To specify the schedule, use valid calendaring expressions. Click the information icon or the Calendaring Expression icon to view examples of commonly used expressions. The scheduling syntax is not case sensitive. | 
| Purge Type | Select the type of purge script to run. This is a required field. 
 For more information about the single (looped) and purge parallel scripts, see Looped Purge Script and Looped Purge in Parallel Script with dbms_scheduler. | 
| Retain Data | Specify the time interval in days for which to retain data. Data within this interval is not purged when the job runs. The default value is seven days. For example, if you specify a data retention interval of seven days, data is protected from purging for the seven days since it was created. Older data already in the system is retained seven days from when automatic purging was enabled.You can ignore the retain data filter by setting this property to  | 
| Maximum Flows to Purge | Select the maximum number of instance flows to purge in a single job run. | 
| Batch Size | Select the maximum number of business flows to delete at a time. The default value is  This field is displayed if Parallel is selected from the Purge Type list. | 
| Degree of Parallel | Select the number of job executions to run in parallel. The default value is  This field is displayed if Parallel is selected from the Purge Type list. | 
To view and configure advanced configuration properties in the System MBean Browser, click More Auto Purge Configuration Properties.
Click PurgeJobDetails.
The two predefined database purge jobs are displayed.
delete_instances_auto_job1
delete_instances_auto_job2
Expand a job to display all properties for single and parallel purges. When either the single or parallel purge type is executed, the appropriate property values for the selected type are executed.
Note:
If you need to edit the advanced purge properties, do so with extreme care. For example, do not change the job names.
View or change values, then click Apply.
| Field | Description | 
|---|---|
| DOP | Defines the number of job executions to run in parallel. The default value is  | 
| PQS | Displays the number of parallel query slaves. You can add additional slaves to improve performance of expensive SQL commands. | 
| batchSize | Displays the maximum number of business flows to delete at a time. The default value is  | 
| Enabled | Indicates if the database purge job is enabled. | 
| executionSchedule | Displays the job scheduling syntax. | 
| ignoreState | When set to  Note: Use this parameter cautiously because purging open instances may leave your system in an inconsistent state. | 
| maxCount | Displays the maximum number of flows to purge. | 
| maxCreationPeriodDays | Displays the maximum creation period in days. This property is used with minCreationPeriodDays for selecting the flows created between a certain period. | 
| maxRuntime | Expiration at which the purge script exits the loop. The default value is  | 
| minCreationPeriodDays | Displays the minimum creation period in days. This property is used with maxCreationPeriodDays for selecting the flows created between a certain period. | 
| purgePartitionedComponent | Indicates if partitioned tables should be purged. If set to  Note: If tables are partitioned, you do not want to purge them because they are maintained by a  | 
| purgeType | Displays either single or parallel. | 
| retentionPeriodDays | Specifies the time interval in days for which to retain data. Data within this interval is not purged when the purge job runs. | 
| sqlTrace | If set to  For information about SQL Trace, see the Oracle Database SQL Tuning Guide. | 
Note:
Retention period does not operate at the granularity of hours. So, if the retention period is set to 1 day, it does not mean that a job will be purged within 24 hours of its completion. Instead, it can take up to 48 hours (i.e. with a retention period of 1 day, if a flow completes at 12:01am on the 20th, it will not be purged until 12:00am on the 22nd).Note:
When upgrading Oracle SOA Suite Release 11g to 12c, do not start the Upgrade Assistant while the purge scripts are running. Wait until the purge is complete before starting the upgrade process. The upgrade fails if the purge scripts are running while using the Upgrade Assistant to upgrade your schemas. For more information about upgrading, see Upgrading Oracle SOA Suite and Business Process Management.
You can run the purge scripts in SQL*Plus to automatically remove older flow instances, adapter reports, and fault alerts data from the database. There are two types of purge scripts:
Looped purge script
Looped purge in parallel script with dbms_scheduler
The master purge script includes a looping construct that allows for a batched purge. You can also provide this script with a max_runtime parameter that stops looping after the value for this parameter is exceeded.
The master script drives the purge of SOA database tables. You can use the delete_instances procedure to purge SOA database tables.
Note:
Set max_runtime to a higher value if there are many instances to purge. In this case, you should expect to wait for a longer time before the script exits. Alternatively, use a smaller batch size if you want the purge script to exit sooner.
Use the delete_instances procedure to delete instances. The following example shows the syntax:
procedure delete_instances (
                   min_creation_date in timestamp,
                   max_creation_date in timestamp,
                   batch_size in integer,
                   max_runtime in integer,
                   retention_period in timestamp,
                   purge_partitioned_component in boolean
                   ignore_state in boolean
                   composite_name in varchar2
                   composite_revision in varchar2
                   soa_partition_name in varchar2
                   sql_trace in boolean
                   PSQ integer
                   );
Table 13-2 describes the script parameters.
Table 13-2 delete_instances Procedure Parameter Descriptions
| Parameter | Description | 
|---|---|
| 
 | Minimum creation period in days for the business flow instances. | 
| 
 | Maximum creation period in days for the business flow instances. | 
| 
 | Maximum number of flows selected for deletion and committed in one execution of the single loop purge. The default value is  | 
| 
 | Expiration at which the purge script exits the loop. The default value is  | 
| 
 | Specify the time interval in days for which to retain data. Data within this interval is not purged when the job runs. The default value is seven days. The retention period is based on the entire flow. The period is compared to  This parameter checks for and deletes records in the  Specify a retention period if you want to retain the business flow instances based on the  In this example, the  min_creation_date = 1st June 2011 
      max_creation_date = 30  June 2011
      retention_period = 1st July 2011This deletes all business flow instances in which the  | 
| 
 | Indicates if partitioned tables should be purged. If set to  Note: If tables are partitioned, you do not want to purge them because they are maintained by a  | 
| 
 | When set to  Note: Use this parameter cautiously because purging open instances may leave your system in an inconsistent state. | 
| 
 | The name of the SOA composite application. This parameter, along with the  | 
| 
 | The revision number of the SOA composite application. | 
| 
 | The partition in which the SOA composite application is included. | 
| 
 | When set to  GRANT ALTER SESSION TO SOA_INFRA Note: Only use this parameter for debugging because it impacts performance. | 
| 
 | Displays the number of parallel query slaves. You can add additional slaves to improve performance of expensive SQL commands. | 
Note:
If you do not provide a value for retention_period, the value for this property defaults to the value of max_creation_date (this is, if retention_period equals null, then retention_period = max_creation_date). This consequence also applies to the script parameters described in Looped Purge in Parallel Script with dbms_scheduler.
If you are not upgrading from Release 11g to 12c, the max_creation_date and min_creation_date parameters are optional. The purge can be run entirely by retention_period, which is also optional.
The purge scripts are restricted to purging only the database and existing rows in a table. There is no way for the purge script to look at runtime execution. Therefore, assume you attempt an automatic recovery immediately after an active row has been deleted with the purge scripts (with the ignore_state parameter set to true). Because of this, a row is created after the purge has been executed. This row remains dangling because the SCA_FLOW_INSTANCE table row has already been deleted.
This script is functionally the same as the looped purge script described in Looped Purge Script. However, this script uses the dbms_scheduler package to spawn multiple purge jobs, with each job working on subset data.
You can use the following procedure to purge SOA database tables.
Note:
If you have a multiple CPU host, use of the parallel script can be beneficial. However, Oracle recommends that you enable the parallel script only during off hours. In addition, when purging data during off hours, Oracle recommends that you drop indexes before purging large amounts of data and then add the indexes back in. This speeds up the purge process, and also keeps indexes from becoming unbalanced.
Use the delete_instances procedure in parallel to delete instances. The following example shows the syntax.
PROCEDURE delete_instances_in_parallel (
                   min_creation_date in timestamp,
                   max_creation_date in timestamp,
                   batch_size in integer,
                   max_runtime in integer,
                   retention_period in integer,
                   DOP in integer
                   max_count integer,
                   purge_partitioned_component in boolean)
                   ignore_state in boolean
                   composite_name in varchar2
                   composite_revision in varchar2
                   soa_partition_name in varchar2
                   sql_trace in boolean
Table 13-3 describes the script parameters.
Table 13-3 delete_instances in Parallel Procedure Parameter Descriptions
| Parameter | Description | 
|---|---|
| 
 | Minimum creation period in days for the business flow instances. | 
| 
 | Maximum creation period in days for the business flow instances. | 
| 
 | Maximum number of flows selected for deletion. The default value is  | 
| 
 | Expiration time at which the purge script exits the loop. The default value is  | 
| 
 | Specify the time interval in days for which to retain data. Data within this interval is not purged when the job runs. The default value is seven days. The retention period is based on the entire flow. The period is compared to  | 
| 
 | Defines the number of job executions to run in parallel. The default value is  | 
| 
 | Defines the number of rows processed (not the number of rows deleted). A big  | 
| 
 | You can invoke the same purge to delete partitioned data. The default value is  Note: If tables are partitioned, you do not want to purge them because they are maintained by a  | 
| 
 | When set to  Note: Use this parameter cautiously because purging open instances may leave your system in an inconsistent state. | 
| 
 | The name of the SOA composite application. This parameter, along with the  | 
| 
 | The revision number of the SOA composite application. | 
| 
 | The partition in which the SOA composite application is included. | 
| 
 | When set to  GRANT ALTER SESSION TO SOA_INFRA Note: Only use this parameter for debugging because it impacts performance. | 
This section describes how to execute the purge scripts. You can also execute these scripts in Deleting Large Numbers of Instances with .
To execute the purge scripts:
In SQL*Plus, connect to the database AS SYSDBA:
CONNECT SYS AS SYSDBA
Execute the following SQL commands:
GRANT EXECUTE ON DBMS_LOCK TO USER; GRANT CREATE ANY JOB TO USER;
where USER is the soainfra account to execute the scripts. These privileges are required to run the scripts.
Load the purge scripts by running the main purge script at MW_HOME/SOA_ORACLE_HOME/soa/common/sql/soainfra/sql/oracle/121300/soa_purge/so a_purge_scripts.sql.
For a parallel purge, the debug logs from the jobs spawned by a parallel purge are logged into files created in the directory named SOA_PURGE_DIR. This directory must be accessible to the Oracle database.
Create SOA_PURGE_DIR and grant write permissions to the soainfra user.
mkdir -p /tmp/purgelog
CREATE OR REPLACE DIRECTORY SOA_PURGE_DIR AS 'SERVER_DIRECTORY'
where SERVER_DIRECTORY is the name of the directory to create (for example, '/tmp/purgelog/'). Note the required single quotes around the directory path.
If you want to execute the scripts in debug mode, run common/debug_on.sql and set serverout to on in SQL*Plus. This step is optional.
SET SERVEROUT ON
The logs from the spawned jobs are logged into the directory created in Step 4(separate files per job). The rest of the logs are displayed on stdout (or the spool file, if configured).
There are two options for purging:
Looped purge
Parallel purge
Execute the purge scripts as shown below. Examples are provided for both options.
For looped purge:
DECLARE
   MAX_CREATION_DATE timestamp;
   MIN_CREATION_DATE timestamp;
   batch_size integer;
   max_runtime integer;
   retention_period timestamp;
   composite_name varchar2(500);
   composite_revision varchar2(50);
   soa_partition_name varchar2(200);
   PQS integer;
   ignore_state boolean; 
  BEGIN
   MIN_CREATION_DATE := to_timestamp('2010-01-01','YYYY-MM-DD');
   MAX_CREATION_DATE := to_timestamp('2010-01-31','YYYY-MM-DD');
    max_runtime := 60;
    retention_period := to_timestamp('2010-01-31','YYYY-MM-DD');
    batch_size := 10000;
    composite_name := 'example_composite';
    composite_revision := '1.0';
    soa_partition_name := 'default';
    ignore_state := false;
    PQS := 5; 
     soa.delete_instances(
     min_creation_date => MIN_CREATION_DATE,
     max_creation_date => MAX_CREATION_DATE,
     batch_size => batch_size,
     max_runtime => max_runtime,
     retention_period => retention_period,
     purge_partitioned_component => false);
     ignore_state => ignore_state,
     sql_trace => true); 
  END;
  /
For parallel purge:
DECLARE
   max_creation_date timestamp;
   min_creation_date timestamp;
   batch_size integer;
   max_runtime integer; 
   retention_period timestamp;
   composite_name varchar2(500);
   composite_revision varchar2(50);
   soa_partition_name varchar2(200);
   PQS integer;
   DOP integer;
   max_count integer;
   ignore_state boolean; 
  BEGIN
   min_creation_date := to_timestamp('2010-01-01','YYYY-MM-DD');
   max_creation_date := to_timestamp('2010-01-31','YYYY-MM-DD');
   batch_size integer;
   max_runtime integer; 
   retention_period := to_timestamp('2010-01-31','YYYY-MM-DD');
   composite_name := 'michael_composite';
   composite_revision := '1.0';
   soa_partition_name := 'default';
   ignore_state := true;
   PQS := 5;
   DOP := 2;
   max_count := 100000; 
    soa.delete_instances_in_parallel(
     min_creation_date => min_creation_date,
     max_creation_date => max_creation_date,
     batch_size => batch_size, 
     max_runtime => max_runtime, 
     retention_period => retention_period,
     DOP => DOP,
     max_count => max_count,
     purge_partitioned_component => false,
     ignore_state => ignore_state,
     sql_trace => true);
   END;You may observe a dead lock in the thread logs for one thread after running the looped purge in parallel script. The following example shows the error found in the thread logs:
SOA_PURGE_LOG_THREAD1 (total of 4 threads) 17-JUL-2012 03:03:48 : Purge AUDIT_DETAILS. Error Code = -60, Error Message = ORA-00060: deadlock detected while waiting for resource 17-JUL-2012 03:03:48 : ERROR(delete_inst_in_parallel_job. Error Code = -60, Error Message = ORA-00060: deadlock detected while waiting for resource
To resolve the dead lock issue, rebuild the AUDIT_DETAILS table and increase the values for either of the following:
Increase PCTFREE (to allow for more interested transaction list (ITL) allocation).
Increase INITRANS (initial ITLs). This option is described below.
To recreate the AUDIT_DETAILS table and increase the INITRANS value:
You can purge the instances of a specific SOA composite application and leave the instances of other composites unpurged. This action enables you to purge certain flows more frequently than others due to high volume or retention period characteristics.
The purge scripts include an option for purging based on COMPOSITE_DN. Purging based on COMPOSITE_DN is supported with the parameters composite_name and composite_revision.
The purge logic is based on flows IDs, and not COMPOSITE_IDs. Therefore, apart from the intended COMPOSITE_DNs, other composites sharing the same flow ID may get deleted. The following scenarios may occur:
A business flow instance is closed, but the flow is still open:
In a scenario in which composite A calls composite B, the purge intends to delete instances of composite A. However, there may be a case in which an instance of composite A is closed, but the corresponding composite B instance is still open. Therefore, because the overall flow is still in an open state, the composite A instance (even though closed) is not purged.
The business flow instance is closed and the flow is also closed:
Composite A again calls composite B. The purge intends to delete instances of composite A. Therefore, in a case in which composite A is closed and composite B is also closed, because the overall flow is closed, both business flow instances A and B are purged.
These scenarios maintain the consistency of the flow.
For information about the composite_name and composite_revision parameters, see Looped Purge Script and Looped Purge in Parallel Script with dbms_scheduler.
The purge scripts include purge commands to purge the information persisted in the Oracle Mediator resequencer tables (MEDIATOR_GROUP_STATUS and MEDIATOR_RESEQUENCER_MESSAGE). The following information is purged from the resequencer tables when you run the purge scripts:
Completed and aborted messages for all resequencer types
Timed out messages for standard resequencers
Groups in a ready state for best effort and FIFO (first in/first out) resequencers (these are the only groups that can be purged)
To allow fault recovery and message processing to be completed, the purge scripts do not purge all resequenced message information. In addition, standard resequencer groups store information that should not be purged. The following are not purged when you run the purge scripts:
Faulted messages for all resequencer types
Running messages for all resequencer types
Group information for standard resequencers
Groups in a state other than ready for best effort and FIFO resequencers
Note:
The purge scripts for the Oracle Mediator resequencer purge messages first and then move on to groups. If there are messages for a group in the MEDIATOR_RESEQUENCER_MESSAGE table, the group cannot be deleted.
The above describes processing for both looped and parallel processing of the purge scripts, and regardless of whether instance tracking is enabled or disabled. Before any sequence groups are purged, a check is performed to verify that all messages associated with the group are processed.
Below is a list of group state codes used in the resequencer tables:
0: Ready
1: Locked
2: Error
4: Timed out
6: Group error
Below is a list of message state codes used in the resequencer tables:
0: Ready
1: Locked
2: Completed
3: Error
4: Timed out (this is ignored)
5: Aborted
You can monitor purge jobs executed from Oracle Enterprise Manager Fusion Middleware Control with the SQL commands described in Table 13-4.
Table 13-4 SQL*Plus Commands for Monitoring the Status of Purging
| To... | Execute This Command... | 
|---|---|
| Show the job history and status | SQL> select log_date, status from user_scheduler_job_ log where job_name = 'DELETE_INSTANCES_AUTO_JOB1' order by log_date; 
 For information about selecting the job on the Auto Purge page, see Deleting Large Numbers of Instances with . | 
| Show a running job | SQL> select session_id, running_instance, elapsed_time, cpu_used from user_scheduler_running_jobs where job_name = 'DELETE_INSTANCES_AUTO_JOB1'; | 
| Show job details | SQL> select log_date, status, req_start_date, actual_start_date, run_duration from user_scheduler_job_run_details where job_name = 'DELETE_INSTANCES_AUTO_JOB1' order by log_date; | 
| Find the job schedule | SQL> select SCHEDULE_TYPE,START_DATE,REPEAT_INTERVAL from user_scheduler_schedules where schedule_name = 'DELETE_INSTANCES_AUTO_SCH1'; 
 | 
| Find the default job schedule | BEGIN
   DBMS_SCHEDULER.set_attribute (
    name      => 'DELETE_INSTANCES_AUTO_SCH1',
    attribute => 'repeat_interval',
    value     => 'freq=daily; byhour=0; byminute=0; bysecond=0');
END;  | 
| Change the job schedule (for this example, to hourly at the thirtieth minute) | BEGIN
   DBMS_SCHEDULER.set_attribute (
    name      => 'DELETE_INSTANCES_AUTO_SCH1',
    attribute => 'repeat_interval',
    value     => 'freq=hourly; byminute=30');
END;  | 
The purge scripts include a parameter to generate a SQL trace:
If running the purge scripts directly from SQL*Plus, the parameter is named a sql_trace parameter.
If running the purge scripts from the Auto Purge page in Oracle Enterprise Manager Fusion Middleware Control, the parameter is named sqlTrace (located beneath the More Auto Purge Configuration Properties link).
Setting this parameter to true generates a database SQL trace that is placed in the database user dump directory. For the parallel purge script, the SQL trace is also generated for each subordinate parallel purge jobs (J000, J001, and so on).
If parallel query slaves have been enabled in the purge scripts, then trace files are created. The trace files are generated when sql_trace is set. With the parallel purge script, multiple trace files are produced named J*.
For information about SQL Trace, see the Oracle Database SQL Tuning Guide.
The runtime and schema code for the following components has been modified to store the flow creation date column with their transactional tables.
Oracle BPEL Process Manager
Oracle Mediator
Human workflow
Oracle B2B
SOA Infrastructure
Oracle BPM Suite
The CPST_CREATED_DATE column contains the flow creation date time populated by the instance tracking code. This is available as the normalized message property oracle.integration.platform.instance.CommonConstants.SCA_FLOW_INSTANCE_CREATED_TIME.
All SOA components are partitioned on the same partition key. These partitioned components use the same time range and partition ID.
Note:
Before performing complete or partial partitioning, run the purge scripts.
You can select a database profile when running the Repository Creation Utility. The profile determines the size of the SOA database and enables you to use existing performance features of the Oracle database for Oracle SOA Suite-related storage.
Large: Provides a large partitioned schema. This selection is for databases of 200 GB or more.
Small: Provides a small schema with no partitions.
For more information, see Section "Custom Variables" of Creating Schemas with the Repository Creation Utility.
Oracle SOA Suite has been instrumented with partition keys that enable DBAs to take advantage of Oracle RDBMS partitioning features and capabilities. This action enables the schema tables to be range-partitioned on time intervals. This is useful when you must reduce the database maintenance window of large tables. (Though not discussed in this chapter, this also provides for the possibility of archiving partitioned data.)
The task of partitioning the Oracle SOA Suite tables must be performed by an experienced DBA. Since partitioning tables is considered a core DBA skill, this chapter does not provide detailed, step-by-step instructions on how to partition tables. Rather, it provides the DBA with the knowledge and understanding of Oracle SOA Suite schemas and their associated scripts. With this knowledge, the DBA can customize any partitioning strategy for their environment, and incorporate any tuning parameters in response to the performance of their database. Tuning is never a one-size-fits-all proposition or a one-off configuration change. Rather, it is an iterative process of monitoring and tuning.
The following components are associated with their own database schemas:
Oracle BPEL Process Manager
Oracle Mediator
Human workflow
Oracle B2B
SOA Infrastructure
Oracle BPM Suite
For more information about table partitioning, see the Oracle database administration documentation library located at the following URL:
http://www.oracle.com/technetwork/indexes/documentation/index.html
Note:
A hash subpartition is an option the DBA may want to explore, especially for tables with large object (LOB) segments. This can assist with high water (HW) enqueue contention.
A global hash index on primary keys that are monotonically increasing (like CIKEY) may relieve block contention.
For performance reasons, the Oracle BPEL Process Manager, Oracle Mediator, human workflow, Oracle B2B, SOA Infrastructure, and Oracle BPM Suite schemas have no foreign key constraints to enforce integrity. This fact discounts the use of the RDBMS feature known as referential partitioning. This feature provides significant benefits because it equipartitions master and detail tables across foreign key constraints. Equipartioning means that the associated dependent table rows are in a database partition with the same partition key interval as their master table rows.
One benefit of this feature is that the state (for example, completed, faulted, and so on) of each detail row in the equipartition can be inferred from its associated master table row.
Although the RDBMS referential partitioning feature cannot be used, similar behavior can be mimicked to achieve some of the same benefits. The Oracle BPEL Process Manager, Oracle Mediator, human workflow, Oracle B2B, SOA Infrastructure, and Oracle BPM Suite components ensure that the partition key of every detail table row is the same as the partition key of its master table row (that is, the date (timestamp) that is the partition key is pushed down). To then complete the setup, the DBA must ensure that the master and detail tables are range-partitioned on the same intervals. Some examples are provided in subsequent sections of this chapter.
Note:
You may decide that referential integrity of aged partitions is not a concern for your site. For example, the site may have ample disk space, allowing data to significantly age, or there may be no apparent, adverse impact of allowing unreferenced data to be stored in the dependent tables.
Range interval partitioning is a Release 12c extension of the Release 11g range partitioning feature. With range partitioning, you had to manually allocate each partition. With range interval partitioning, you do not need to manually allocate partitions. Partitions of a specified interval are automatically created when the interval value of the partition key that you assign exceeds all of the existing range partitions. The verification scripts support range interval partitioning.
For more information about range interval partitioning, see Oracle Database VLDB and Partitioning Guide.
A goal of equipartitioning is to ensure that all dependent table partitions contain the complete set of associated rows for their master table partitions. This is accomplished as follows:
A partition key value is propagated down from the master key to all dependents so that they have the same range.
The master key contains the state of each flow (open, closed). When the master is checked and everything is closed, dependent tables with the same partition range can be dropped.
The range interval partitioning verification scripts check the following for each dependent table partition against the master partition:
The same interval definition (each table requires the same interval definition for monthly, weekly, number of days, and so on).
The upper and lower bound high values are automatically maintained by the database.
Partitions that must be dropped require the same upper bound high value.
The following example describes how range interval partitioning works. For this example, the SCA_FLOW_INSTANCE master table is used.
CREATE TABLE SCA_FLOW_INSTANCE
(FLOW_ID INTEGER NOT NULL;
. . .
. . .
CREATED_TIME TIMESTAMP NOT NULL)
PARTITION BY RANGE (CREATED_TIME)
INTERVAL(NUMTOYMINTERVAL(1, 'MONTH'))
PARTITION p0 VALUES LESS THAN (TO_DATE('1-2-2007', 'DD-MM-YYYY')));
Table 13-5 describes the syntax shown in the preceding example.
Table 13-5 Range Interval Partitioning Example
| Syntax | Description | 
|---|---|
| PARTITION BY RANGE (CREATED_TIME) | The partition key (for example, a date of July 1, 2013, which is specified as  | 
| INTERVAL(NUMTOYMINTERVAL(1, 'MONTH')) | The interval (for this example, one month is specified). Therefore, if a partition key is specified for July 1 (as  Note: All Oracle SOA Suite tables must be created with this same interval value so that the upper and lower bounds are created with respect to equipartitioning. | 
| PARTITION p0 VALUES LESS THAN (TO_DATE
('1-2-2007', 'DD-MM-YYYY'))); | The first partition must be a range partition. This is the transition point after which all partitions are automatically allocated. It is recommended that the first range partition have a  The date for this partition makes it virtual metadata. This date makes it easier to drop the partition, if necessary. | 
The SQL command shown in the following example identifies the first range partition created. A value of No in the last column indicates that this is a range partition, and not an interval partition.
SQL> select partition position, partition name, high value, interval
      from user_tab_partitions
       where table_name = 'SCA_FLOW_INSTANCE';
--------------------------------------------------------------
1     P0        TIMESTAMP' 2007-02-01 00:00:00'    No
The SQL command shown in the following example identifies the system name, the upper bound high value, and whether this is an interval partition. A value of Yes in the last column indicates that this is an interval partition. The second row in the output is dropped. The first row is simply metadata and is not dropped. The partitions are automatically allocated as you insert the date. System names are automatically generated and partitions are allocated as necessary based on the date.
SQL> INSERT INTO SCA_FLOW_INSTANCE VALUES(..TO_TIMESTAMP('1-5-2013', 'DD-MM-YYYY')...};
 
--------------------------------------------------------------
1     P0        TIMESTAMP' 2007-02-01 00:00:00'    No
2     SYS_P532  TIMESTAMP' 2013-06-01 00:00:00'    Yes
The SQL command shown in the following example identifies the second and third rows as the partitions to drop. Because this is performed over an earlier month (March 2013 instead of May 2013), another partition is inserted. The positions of the partitions are changed.
SQL> INSERT INTO SCA_FLOW_INSTANCE VALUES(..TO_TIMESTAMP('1-3-2013', 'DD-MM-YYYY')...};
 
--------------------------------------------------------------
1     P0        TIMESTAMP' 2007-02-01 00:00:00'    No
2     SYS_P578  TIMESTAMP' 2013-04-01 00:00:00'    Yes
3     SYS_P532  TIMESTAMP' 2013-06-01 00:00:00'    YesThe following factors were considered when selecting the schema partition keys:
Convey or imply state (for example, completed) for referential integrity
Allow range partitioning on time intervals for maintenance operations
Be static to avoid row movement that may lead to unreferenced data
Be static to avoid row movement when table maintenance operations are performed
Provide performance benefits for console queries through partition pruning
Partitioning is not configured by default; it is a postinstallation step that must be performed manually. Once you decide to implement partitioning of the database, you must perform some initial configuration tasks only once:
Using the information in this chapter, decide which groups you want to partition.
For each of those groups, decide which tables you want to partition, remembering that there are some mandatory tables in each group that must be partitioned.
For each group, decide on the partition interval.
Create the partition scripts to partition the Oracle SOA Suite schemas. No scripts are supplied; each DBA is responsible for creating the partition scripts appropriate for their environment.
A verification script is provided for a DBA to identify when to drop a partition and its equipartitioned dependent table. The verification script also identifies if there are active, long running instances. You can then move these instances to a different partition, and then drop the original partition. The verification scripts support range interval partitioning.
Note:
The verification script does not drop any partitions; it just ensures that partitions are eligible to be dropped. It is important to enable partitioning for all tables for the scripts to get correct data
This section describes partitioning constraints and lists the component tables, the groups to which they belong, and their partition key.
Note the following table partitioning constraints:
You have the choice of the following approach to partitioning:
Complete partitioning: All tables of a service component/service engine are partitioned.
No partitioning: No tables of a service component/service engine are partitioned.
Partial partitioning: Restrict partitioning to specific tables with a high growth rate.
You can partition any of the tables by following these constraints:
If you want to partition a dependent table, you must also partition its master table.
All tables should be equipartitioned along the same date ranges and the same name.
Always partition the SCA_FLOW_INSTANCE table. This constraint is essential when the Audit Level property is set to Development or Production for any of the composites. The verification script checks for active flows based on the active business flow instances within that partition. Therefore, if the SCA_FLOW_INSTANCE table is not partitioned, the entire verification script logic based on the equipartitioning of all the tables fails.
Regardless of the group and component, all tables that are partitioned use the same time range and the partition ID.
Table 13-6 through Table 13-11 are divided into three groups.
Group 1: This includes tables that are directly related to the end-to-end flow trace of a composite. A majority of the tables fall into this group.
Group 1A: This includes a small set of tables that are not directly related to the flow trace.
Group 2: This includes a small set of tables that have a dependency on multiple tables from Group 1 and 1A tables. You must first execute the group 1 verification script and drop the group 1 partitions before running the group 2 verification script.
Note:
Groups 1 and 1A are combined in the verification script. Running the verification script does not require you to have knowledge of this classification.
Table 13-6 Component: SOA Infrastructure
| Table | Range Partition Key | Group | 
|---|---|---|
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
Table 13-7 Component: Oracle BPEL Process Manager
| Table | Range Partition Key | Group | 
|---|---|---|
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1A | 
| 
 | 
 | 1A | 
| 
 | 
 | 1A | 
| 
 | 
 | 2 | 
Table 13-8 Component: Oracle Mediator
| Table Name | Range Partition Key | Group | 
|---|---|---|
| 
 | 
 | 1 | 
| 
 | 
 | 2 | 
Table 13-9 Component: Human Workflow
| Table | Range Partition Key | Group | 
|---|---|---|
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
Table 13-10 Component: Oracle B2B
| Table | Range Partition Key | Group | 
|---|---|---|
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
Table 13-11 Component: Oracle BPM Suite
| Table | Range Partition Key | Group | 
|---|---|---|
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
| 
 | 
 | 1 | 
The verification script uses following two tables when performing checking:
USER_PART_TABLES
USER_TAB_PARTITIONS
To check the interval definition that you defined for your table:
SQL> select INTERVAL from USER_PART_TABLES 
     where table_name = 'table_name';
To check the upper bound high value for a partition:
SQL> select high_value from USER_TAB_PARTITIONS
     where table_name = 'table_name'
     and partition_name = 'partition_name';MW_HOME/SOA_ORACLE_HOME/rcu/integration/soainfra/sql/verify. There are two versions of the verification script, depending on whether your schema is Interval partitioned or Range partitioned:
soa_exec_interval_verify.sql
soa_exec_verify.sql
The verification script helps determine if a partition can be dropped. When you execute the verification script, a log file and a result file is generated for each partition. The log file should be examined by the database administrator to assess if a partition can be dropped by running the result file.
On examining the log file, the database administrator might find that there are too many active instances, and decide to let the partition age further. If the database administrator finds that only a small number of instances are open, say 5%, the administrator may decide to execute row movement to move these instances to another partition. Once the active instances in a partition have been moved to another partition, the partition can be dropped.
To execute the verification script:
Note:
A verification script is not provided for business rules.
Moving rows is expensive, as the row movement procedure needs to move the rows in all the equi-partitioned tables. When planning a partitioning strategy, ensure that the partitions are allowed to age sufficiently, so that the percentage of open instances is less than 5% of the total number of rows in the partition.
Oracle SOA Suite includes several routines to assist with the database side of partition maintenance. Routines include scripts to enable and disable foreign keys, alter intervals for interval-partitioned tables, and restore rows after row movement.
The row movement and other partition maintenance routines were included in 12.1.3 through patch 21181834. The routines have been included in 12.2.1 through patch 21520523. The following routines are described below:
Row Restore (verify_soa.exec_row_restore_1)
This routine is used to restore the Group 1 table partition keys back to their original values. You can run the row restore routine once the flows have been row-migrated, and the appropriate partitions have been dropped. Once the routine completes successfully, you can execute the Row Restore Truncate routine.
BEGIN verify_soa.exec_row_restore_1; END;
Row Restore Truncate (verify_soa.trunc_verify1_rst_temp_tables)
This routine truncates the table verify_r_group1. Run this only after the Row Restore routine has been successfully run. The Row Restore routine should be repeated until successful. Once you run Row Restore Truncate, the Row Restore routine cannot be repeated. (NOTE: Consider backing up table verify_r_group1 prior to the truncation).
Note:
Consider backing up the table verify_r_group1 before running the truncate routine.
BEGIN verify_soa.trunc_verify1_rst_temp_tables; END;
Alter Interval (verify_soa.alter_interval)
Use this routine to alter the interval for Interval partitioned tables. The routine generates a SQL script in the PART_DIR directory. The SQL script can then be executed by the SOAINFRA user.
Step 1: Generates the SQL Script
set echo on;
set serverout on;
/*
NUMTOYMINTERVAL(1, ''MONTH'')
NUMTODSINTERVAL(1, ''DAY'')
NUMTODSINTERVAL(7, ''DAY'')
*/
begin
 verify_soa.alter_interval('NUMTODSINTERVAL(1, ''DAY'')');
end;
Step 2: Runs the Generated SQL Script
SQL> @SOA_ALTER_INTERVAL_GROUP1.SQL
Alter Foreign Keys (verify_soa.alter_FK)
Use to disable the foreign keys before dropping a partition, and then to re-enable the foreign keys after the partition drop command. The routine generates two SQL scipts in the PART_DIR directory. The SQL scripts can be customized to suite your performance requirements. The SQL scripts must be run as the SOAINFRA user.
Step 1: Generates the SQL Scripts:
set echo on; set serverout on; begin verify_soa.alter_fk; end;
Step2: Runs the enable and disable commands, as required:
SQL> @SOA_DISABLE_FK.SQL SQL> @SOA_ENABLE_FK.SQL
If you have an environment in which some components are partitioned, while other components are not partitioned, the nonpartitioned data set must be purged using the purge scripts described in Deleting Large Numbers of Flow Instances_ Adapter Reports_ and Fault Alerts.
For example, assume human workflow is not partitioned, while other components are partitioned. The verification script reports that all SOA partitions can be dropped using the command for dropping partitions. However, the human workflow tables continue to hold workflow data until the data is purged using the loop/parallel purge scripts.
The truncate scripts (truncate_soa_oracle.sql and, for the Java database provided with the Oracle SOA Suite Quick Start installation, truncate_soa_javadb.sql) enable you to remove all records from all Oracle SOA Suite runtime tables without dropping the tables. You cannot reclaim database space with the truncate scripts.
The truncate scripts are useful for the following scenarios:
To create a production or test environment clone (test-to-production or production-to-test) in which you want to keep the schemas from the production environment so that the production customizations and new job definitions are kept, but all instance data in the SOA Infrastructure (that is, in the cloned database) must be truncated, regardless of state.
For testing purposes in which test scenarios must be recreated and rerun.
The truncate scripts provide this option by including truncate statements covering all the runtime tables of the following components:
Oracle BPEL Process Manager
Oracle Mediator
Business rules
Oracle B2B
SOA Infrastructure
Oracle BPM Suite
To remove records from the runtime tables without dropping the tables: