Oracle SOA Suite Online Training

Interested in learning Oracle SOA Suite 12c?
Learn from the author of this blog!
A complete and comprehensive course on the #1 platform on SOA - Oracle SOA Suite

Click here to find the complete course details
Click here to check the first session on Oracle SOA Suite 12c

================================================================================================

Composite Instance Migration across different revisions

Often you find scenarios where you may want to migrate the running instances in one revision to another. A very common example for this is when you make some critical changes in your process, and you want all the older, already started but running instances, to continue in this new revision.

In such cases, the ant script ant-composite-instance-migration.xml will come handy

Location : <ORACLE_HOME>/bin/ant-composite-instance-migration.xml

Please note that this file has some errors in the jar locations, so cross-verify.

Create a build script for using this ant file. You need to provide the following information
1. Server details
2. Source Revision
3. Target Revision

Here's my build.xml file

--------------------------------------------------------------------------------------------------------------------
<?xml version="1.0" encoding="iso-8859-1"?>
<project name="migration-approvalProcess-straightMigration">
    <!--
        CREATE/MODIFY THE FOLLOWING
        ===========================
ENVIRONMENT VARIABLE ORACLE_HOME
REPORTS DIRECTORY VALUE
SERVER DETAILS IN <locatorConfig>
SOURCE COMPOSITE REVISION AND FILTER CONDITIONS IN <compositeInstanceFilterDef>
TARGET COMPOSITE REVISION IN <generateMigrationReport> AND <migrateCompositeInstances>
NOTE : MIGRATION PLAN IS NOT REQUIRED FOR MIGRATION FLAGGED AS AUTOMATIC
-->
    <property environment="envVar"/>
    <property name="srcBpmRevision" value="1.0"/>
    <property name="targetBpmRevision" value="2.0"/>
    <import file="${envVar.ORACLE_HOME}/bin/ant-composite-instance-migration.xml"/>
    <property name="reports.dir" value="${basedir}/MigrationReports"/>
    
    <!-- SERVER CONNECTION DETAILS -->
    <locatorConfig id="c1" host="asdf.abc.com" port="10030" user="userid" password="pwd"/>
    
    <target name="migrateCompositeInstances">
        <compositeInstanceFilterDef id="f1" domainname="default" compositedn="default/ApprovalProcess_InstanceMigration!${srcBpmRevision}" compositeinstanceid="2410732"/>
        <locatorSession configid="c1">
            <generateMigrationReport filterid="f1" revision="${targetBpmRevision}" outputfile="${reports.dir}/MigrationFeasibilityReport_AutomaticMigration_${srcBpmRevision}.xml"/>
            <!-- Migration Plan is not required for automatic migration -->
            <migrateCompositeInstances  filterId="f1" revision="${targetBpmRevision}" outputFile="${reports.dir}/MigrationResultReport_AutomaticMigration_${srcBpmRevision}.xml"/>
        </locatorSession>
    </target>

</project>

--------------------------------------------------------------------------------------------------------------------

Understanding the build file
compositeInstanceFilterDef : Filter for what instances to migrate. You can use various filter attributes like
id*, compositeDN*, flowId, pageStart, pageSize, tenantId, maxCreationDate, minCreationDate, maxModifyDate, minModifyDate, like, ecid, conversationId, compositeName, domainName, label, revision, title (* - Mandatory)
generateMigrationReport : This generates a report with the migration feasibility. It is a good practice to run only this first, analyse the report and then run the actual migration
migrateCompositeInstances : This runs the migration


Note that for those instances where the migration is marked as 'automatic' in the feasibility report do not require a migration plan, they can straight away be migrated.