13 Data Migration between UIM and ATA
This chapter describes how to perform the data migration between UIM and ATA.
Planning the Topology Migration
In preparation for implementing ATA, you must set up the topology migration and UIM to topology configuration. The UIM to topology migration extracts and loads necessary information from UIM into the topology graph model consisting of vertices and edges. Following the Database per Service Micro service Design Pattern, the topology graph resides in a Pluggable Database (PDB) container separated from the UIM database.
The migration consists of the following:
- Index Rebuilding: The index rebuilding consists of re-creating indexes on tables with migrated data, dropping the temporary tables created during migration and renaming the tables with migrated data to actual topology tables.
Data Migration Approaches
You can follow the following approaches for data migration:
- Data Migration through Database Link: Database Link (DBLink) is created from ATA schema to UIM schema.
- Data Migration through Read Access on UIM schema: ATA schema is set up within the same PDB as that of the UIM schema. ATA schema user is granted with SELECT (read access) along with the tables owned by UIM schema user. Data dump files are created for the migrated topology data. These dump files are then imported in the target PDB where the ATA schema will be placed.
The prerequisites are:
- 
                        
                        Add DATAFILE to increase the TABLESPACE available (SYSTEM by default) for the ATA schema user. Preferably one-fourth the size of UIM schema. 
- 
                        
                        Data Migration to custom tablespace can be achieved by making the custom tablespace as the default tablespace for the ATA schema user. 
The Migration Steps are as follows:
- Build Characteristics tables for the following topology enabled
                entities such as Equipment, Logical Device, Network, Network Edge, Physical Device,
                Pipe and Place. These <ENTITY>_CHAR_MIG tables are used to store all
                characteristics on each entity which are used during Dynamic Attribute Migration and
                Customizing Topology JSON files. Build <ENTITY>_CHAR_MIG tables:
                        - Open a command line window and login to SQL*Plus for the UIM database.
- Run the following SQL scripts providing the full path of the
                        files. For example, use the @scriptFileName command where scriptFileName is
                        the full path and name of the file.
                              - $WORKSPACEDIR/ata-builder/migration_scripts/Char_Mig_tables/CREATE_CHAR_MIG_TABLE.sql
- $WORKSPACEDIR/ata-builder/migration_scripts/Char_Mig_tables/MIGRATION_CHAR1.sql
- $WORKSPACEDIR/ata-builder/migration_scripts/Char_Mig_tables/ MIGRATION_CHAR2.sql
- $WORKSPACEDIR/ata-builder/migration_scripts/Char_Mig_tables/ MIGRATION_CHAR3.sql
 
- To verify if the scripts ran successfully, you can verify that
                        the UIM schema includes the following tables:
                              - EQUIPMENT_CHAR_MIG
- LOGICALDEVICE_CHAR_MIG
- NETWORK_CHAR_MIG
- NETWORKEDGE_CHAR_MIG
- PHYSICALDEVICE_CHAR_MIG
- PIPE_CHAR_MIG
- PLACE_CHAR_MIG
- CHARACTERISTICS_TABLE_MAPPING_MIG
 
 Note: You can perform this step for any of the data migration approaches.
- The Topology schema user account must have the following privileges:
                    
                        - CREATE JOB
- CREATE SESSION
- ALTER SYSTEM
- CREATE DATABASE LINK
- CREATE PROCEDURE
- CREATE SEQUENCE
- CREATE TABLE
- CREATE TYPE
- UNLIMITED TABLESPACE
- CREATE JOB
 These above privileges are sufficient for Approach 1, however for Approach 2: - Create SYNONYM.
- Grant SELECT permission to all the tables owned by UIM schema user and ATA schema user.
 CREATE PROCEDURE grant_select( username VARCHAR2, grantee VARCHAR2) AS BEGIN FOR r IN ( SELECT owner, table_name FROM all_tables WHERE owner = username ) LOOP EXECUTE IMMEDIATE 'GRANT SELECT ON '||r.owner||'.'||r.table_name||' to ' || grantee; END LOOP; END; “username” – UIM Schema User “grantee” – ATA Schema User within the same PDB.
- Static Attribute Migration: 
                        - Open a command line window and login to SQL*Plus for the Topology database.
- Approach 1: 
                              - Migrate the static attributes data by running $WORKSPACEDIR/ata-builder/migration_scripts/data_migration_script_using_dblink.sql
- The following input arguments are expected:
                                    - UIM schema username
- UIM schema password
- Database Hostname
- Database port number
- Database Service name
- Commit Size(Optional – 50000(Default))
- Maximum number of parallel processes(Optional – 5(Default))
- Wait Time(Optional – 2(Default in seconds))
 
 
- Approach 2:
                              - Migrate the static attributes data by running $WORKSPACEDIR/ata-builder/migration_scripts/data_migration_script_using_localCopy.sql
-  The expects the following input arguments:
                                    - UIM schema username with in the PDB
- Commit Size(Optional – 50000(Default))
- Maximum number of parallel processes(Optional – 5(Default))
- Wait Time(Optional – 2(Default in seconds))
 
 
 Note: Commit Size: The number of records handled by a single process, Maximum number of parallel processes – Depends on number of CPU’s available, Wait Time – Waiting interval after which the listener checks for the availability of jobs.
- Modify the topology JSON files in
                    $WORKSPACEDIR/ata-builder/migration_scripts/scriptGenerator/scriptGenerator_Execuable/topologyjsonfiles/
                and run the following commands:
                        Approach 1: java -jar scriptgenerator_dblink-1.0-jar-with-dependencies.jar Approach 2: java -jar scriptgenerator_localCopy-1.0-jar-with-dependencies.jar 
- Dynamic Attribute Migration: Once the scriptgenerator_<Approach>-1.0-jar-with-dependencies.jar is run, the SQLs required for Dynamic attribute migration are generated in $WORKSPACEDIR/ata-builder/migration_scripts/scriptGenerator/scriptGenerator_Executable/scriptOutFiles/dynamicAtt.sql. Run the SQL queries sequentially.
-  Verify the migrated data by going through tables with %_FINALor%_NEWname.
- Index Rebuild: The tables with names as %_FINALand%_NEWcontain the actual migrated data and indexes and constraints have to be added to these tables, these are generated in $WORKSPACEDIR/ata- builder/migration_scripts / scriptGenerator/scriptGenerator_Executable/ scriptOutFiles/indexRebuild.sql. Run the SQL queries sequentially.
- In case of performing data migration using Approach 2, export the migrated Topology Data and import the migrated Topology Data into the target PDB where the ATA schema is expected to be.
- Oracle Optimizer determines the cost of each execution plan based on
                database, schema, table and other statistics. The changes inside database result in
                stale statistics. To gather new statistics, run the following
                command:EXEC DBMS_STATS.gather_schema_stats( '<TopologySchema_Name>' );
Note:
PG_PROFILE tables which store the Service Topology Data are not supported in existing migration. If you want service topology profile data in the topology schema you can create a new service configuration and approve it. In 7.5.1.0.0, Profile Data is created for every service configuration in Approved State.
Customizing Topology JSON files for Migration
The $WORKSPACEDIR/ata-builder/migration_scripts/scriptGenerator/scriptGenerator_Execuable/topologyjsonfiles/ contains three topology JSON files:
- topologyAttributeMapping.json
- topologyRoleMapping.json
- topologySpecificationMapping.json
Customize topologyAttributeMapping.json
[
    {
        "name": "LogicalDeviceDAO",
        "properties": [
            {
                "name": "NativeEMSName",
                "property": "NativeEMSName",
                "vertex": "",
                "columnName": ""
            }
        ]
    }
]
TopologyAttributeMapping (TAM) is an array defining how attributes of different DAO’s can map to Topology Schema. Each TAM object consists of key-value pairs of name and properties.
- name – Maps to different entity classes and entity specification classes. For example: “LogicalDeviceDAO”, “EquipmentSpecificationDAO”, “PlaceSpecificationDAO”, “PropertyLocationDAO” and so on.
- properties – This is an array defining how individual attributes of an entity
                are supposed to be stored in Topology schema. Each JSON object of the
                    properties has:
                           - name – Name of the Attribute.
- property – Name of the key used to store the value retrieved from Attribute.
- vertex – Build the relationship with the Vertices, from Topology Schema.
- columnName – Column from Topology Schema used to store the Attribute values.
 
Note:
In “properties” array objects, “name” is a mandatory field to be provided which maps to either “property” or “vertex” or “columnName”.
An example of TAM is:
Assume, the topologyAttributeMapping.json contains the following:
[
    {
        "name": "LogicalDeviceSpecificationDAO",
        "properties": [
            {
                "name": "vendorName",
                "property": "",
                "vertex": "vendor",
                "columnName": ""
            },
            {
                "name": "modelnumber",
                "property": "Model",
                "vertex": "",
                "columnName": ""
            }
        ]
    },
    {
        "name": "EquipmentDAO",
        "properties": [
            {
                "name": " NativeEMSName",
                "property": "",
                "vertex": "",
                "columnName": "DEVICEIDENTIFIER"
            }
        ]
    }
]
In the above example:
- LogicalDeviceSpecification table from UIM schema is expected to have “vendorName”
                and “modelnumber” columns which are used to do the following:
                           - All LogicalDeviceSpecification’s which have a vendorName as some non-null
                        value is moved to PG_VENDOR table and containment edges between the devices
                        of LogicalDevice type and their respective vendors are created in
                        PG_DEVICE_TO_VENDOR table. 
                                 Example: Assume there are 2 Logical Devices (“LDSampleDevice1” and “LDSampleDevice2”) of specification “LDSampleSpec”, and “LDSampleVendor” is the “vendorName”. Then, vertex/record for “LDSampleVendor” is created in PG_VENDOR table and the logical devices have their respective containment edges to the “LDSampleVendor” in PG_DEVICE_TO_VENDOR table. 
- All LogicalDeviceSpecification’s which have a “modelnumber” as some non-null
                        value is stored in “PROPERTIES” column of PG_DEVICE table. For example:
                        “LDSampleSpec” has “APTS-123” as “modelnumber”, then it’s stored
                        as:{ "Model": "APTS-123" }
- 
                                 
                                 Equipments which have non-null value in “NativeEMSName” are stored in “DEVICEIDENTIFIER” column of PG_DEVICE table. 
 
- All LogicalDeviceSpecification’s which have a vendorName as some non-null
                        value is moved to PG_VENDOR table and containment edges between the devices
                        of LogicalDevice type and their respective vendors are created in
                        PG_DEVICE_TO_VENDOR table. 
                                 
[
    {
        "name": "ADM",
        "entityClass": [
            "LogicalDeviceDAO",
            "PhysicalDeviceDAO",
            "EquipmentDAO"
        ],
        "property": "",
        "vertex": "domain",
        "columnName": ""
    }
]
TopologyRoleMapping (TRM) is an array defining how entities which are role-enabled are stored in Topology schema. Each TRM object contains key-values pairs of “name”, “entityClass”, “property”, “vertex” and “columnName”.
- name – Name of the Role.
- entityClass – Entities which are enabled by the role and want data migrated for.
- property – Name of the key used to store the Role.
- vertex – Build the relationship with the Vertices, from Topology Schema.
- columnName – Column from Topology Schema used to store the Role.
Note:
In each TRM object “name” is a mandatory field with role information which can be mapped to either “property” or “vertex” or “columnName”. If “entityClass” is empty ([]) that is same as role information to be checked in Logical Device, Equipment, Physical Device, Place, Pipe and Network.
An example of TRM is:
Assume, the topologyRoleMapping.json contains the following:
[
    {
        "name": "ADM",
        "entityClass": [
            "LogicalDeviceDAO",
            "PhysicalDeviceDAO",
            "EquipmentDAO"
        ],
        "property": "",
        "vertex": "domain",
        "columnName": ""
    },
    {
        "name": "EIGRP",
        "entityClass": [
            "LogicalDeviceDAO"
        ],
        "property": "routingProtocol",
        "vertex": "",
        "columnName": ""
    },
    {
        "name": "Router",
        "entityClass": [
            "EquipmentDAO"
        ],
        "property": "",
        "vertex": "",
        "columnName": "nodeCategory"
    }
]
In the above example,
- A record for ADM is created in PG_DOMAIN table and all logical devices, equipments, and physical devices that are enabled by the ADM role, have the corresponding records in the PG_DEVICE_TO_DOMAIN table.
- All logical devices enabled by the EIGRP role have the
                    PROPERTIES column populated
                with;{ "routingProtocol": "EIGRP" }
- All equipments enabled by the Router role have Router stored in the NODECATEGORY column of PG_DEVICE table.
Customizing “topologySpecificationMapping.json”
[
    {
        "name": "EthernetDevice",
        "entityType": "LogicalDeviceSpecificationDAO",
        "relatedVertices": [
            {
                "vertex": "domain",
                "value": "Ethernet"
            }
        ],
        "characteristics": [
            {
                "name": "zoneID",
                "property": "",
                "vertex": "",
                "columnName": "ZONEID"
            }
        ]
    }
]
TopologySpecificationMapping (TSM) is an array defining how characteristics of a specification are mapped Topology schema and how all entities of a specification can have containment edge to other entities. Each TSM object contains key-values pairs of “name”, “entityType”, “relatedVertices” and “characteristics”.
- name – Name of the Specification.
- entityType – The type of entity does the specification represent.
- relatedVertices – Create containment edges for all entities of the given
                specification with the vertex and value. This contains an array of objects which
                    have:
                           - vertex – To which vertex the containment edges must be created to.
- Value – The value of the vertex.
 
- characteristics – Array of characteristics provided by the specification and how
                they are stored in Topology schema.
                           - name – Name of the characteristic (case-sensitive).
- property- Name of the key used to store the characteristic.
- vertex – Build the relationship with vertices in Topology schema.
- columnName – Column from Topology schema in which the characteristic is stored.
 
Note:
In each TSM object “name” and “entityType” are mandatory fields with specification and type of specification information. “relatedVertices” is used to create direct containment edges for all entities of the specification in question. “characteristics” is an array of objects where “name” is mandatory and talks about the characteristics provided by specification and can be mapped to either “property” or “vertex” or “columnName”.
An example of TSM is:
Assume, the topologySpecificationMapping.json contains the following:
[
    {
        "name": "cableModem",
        "entityType": "PhysicalDeviceSpecificationDAO",
        "characteristics": [
            {
                "name": "deviceType",
                "property": "deviceType",
                "vertex": "",
                "columnName": ""
            }
        ]
    },
    {
        "name": "EthernetDevice",
        "entityType": "LogicalDeviceSpecificationDAO",
        "relatedVertices": [
            {
                "vertex": "domain",
                "value": "Ethernet"
            }
        ],
        "characteristics": [
            {
                "name": "Tech",
                "property": "",
                "vertex": "Technology",
                "columnName": ""
            }
        ]
    },
    {
        "name": "Generic_Address",
        "entityType": "PlaceSpecificationDAO",
        "characteristics": [
            {
                "name": "CityName",
                "property": "",
                "vertex": "",
                "columnName": "city"
            },
            {
                "name": "StateName",
                "property": "",
                "vertex": "",
                "columnName": "state"
            },
            {
                "name": "PostalCode",
                "property": "",
                "vertex": "",
                "columnName": "postalCode"
            }
        ]
    }
]
In the above example,
- “cableModem” is a PhysicalDeviceSpecification which has a characteristic
                “deviceType”. This characteristic is stored in “PROPERTIES” column of PG_DEVICE
                table.{ "DeviceType": "deviceType" }
- A record for “Ethernet” is added to PG_DOMAIN table. All devices of “EthernetDevice” specification have containment edges to “Ethernet” in PG_Device_To_Domain table.
- “EthernetDevice” has a characteristic called “Tech”, so all unique values of “Tech” characteristic are added to PG_Technology. And for each “EthernetDevice” depending on its “Tech” characteristic respective containment edges are built.
- “Generic_Address” is a Place which has “CityName”, “StateName” and “PostalCode” characteristics which are mapped to “CITY”,”STATE” and “POSTALCODE” columns of PG_LOCATION table.
Customizing Topology JSON Files
To customize the topology JSON files:
- 
                              
                              When migrating Attribute or Role or Characteristic data to “PROPERTIES” column of respective entity, make sure the key used doesn’t include any empty space or special characters: { "name": "Vendor Name", "property": "", "vertex": "vendor", "columnName": "" }The above example “Vendor Name” contains empty space. Instead use “VendorName” or “Vendor_Name”. 
- 
                              
                              In topologySpecificationMapping.json if the characteristic being migrated has length greater than 30 characters or contains special characters, the <ENTITY>_CHAR_MIG, do not have the characteristic as is. Instead, it has been casted to coded value, which can be derived from “CHARACTERISTICS_TABLE_MAPPING_MIG” in UIM schema. For example: “Inter-rack_Power_Distribution” (CHAR_NAME) is the name of the characteristic which has been casted to “C46575002” (COLUMN_NAME). { "name": "Inter-rack_Power_Distribution", "property": "", "vertex": "", "columnName": "nodeCategory" }
{
    "name": "C46575002",
    "property": "",
    "vertex": "",
    "columnName": "nodeCategory"
}