Vous êtes sur la page 1sur 36

ODI+OGG Integration

1 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

Integrating Oracle Data Integrator 12c (ODI) and Oracle GoldenGate 12c (OGG)

Purpose
This tutorial covers integrating Oracle Goldengate (OGG) with Oracle Data Integrator 12c (ODI). ODI knows about and can control OGG, OGG does not know about ODI.

Time to Complete
Approximately 2 hours, depending on whether you use the pre-built VM or not (see Software Requirements below).

Introduction
In this tutorial, you will create the sample database users and tables, configure the OGG manager and agents, configure the ODI data servers, models, datastores, maps, agents, and
packages, and then start/stop/control the processes. There will be both OGG replication (capture and delivery) and ODI replication (Change Data Capture via Journaling). The OGG will run
near-real-time, the ODI will run in micro-batches of one row of changed data polling once/second.

Scenario
Suppose the Example Corporation has an Orders Application system that has a Customer table. You want to keep an up-to-date copy of that information on the Sales administration system.
As changes are made to the Orders Customer table, OGG in near-real-time replicates those changes to the Sales Customer table. However, the Sales system requires the format of the data
to be transformed into a slightly different layout. ODI will do the transformation of only the rows that have changed.

When showing terminal sessions of the above scenario, the logical and physical E-LT flow will be as follows:
Source will be the Orders Application OGG_ODI_DEMO_SRC.OGG_CUSTOMER table shown with a BLUE banner.
Staging will be the Sales Administration ODI_DEMO.OGG_CUSTOMER table shown with a RED banner.
Target will be the Sales Administration ODI_DEMO.TRG_CUSTOMER table shown with a GREEN banner.

Hardware and Software Requirements


There are two ways you can do this tutorial: either install all the software yourself on your own host(s), or use a virtual machine (VM) with most everything pre-installed. The advantage of the
VM is, of course, that it is easier and faster, but it may not exactly represent your final environment, in which case you may want to go through the extra steps to install everything yourself. The
tutorial will assume you are using the VM, but will include some of the extra steps for the recreating preinstalled bits.
The following is a list of hardware and software requirements:
Hardware
If you are using the VM, it requires 4 GB itself, usually hosted on a PC with 8 GB total. The VM assumes a host PC with 4 CPUs; you may need to adjust that down if you have
fewer real CPUs. The VM works fine with 2 CPUs.
If you are running the software on a real host(s), you need enough RAM to support the processes. If you have multiple hosts, the RAM can be distributed per host.
Each DB requires at least 1 GB (Enterprise Edition (EE) may require 2 GB)
Each OGG instance requires at least 1 GB
ODI requires at least 1 GB
The OS requires at least 1 GB. More is better.
Enough disk to support the installs, including unzipping the images.
Software
If you are using the VM, you will need:
The Oracle VirtualBox player
The VM image (approx 9 GB)
The demo VM Getting Started with ODI 12c guide.
If you are installing the software yourself in Standalone mode, you will need:
Three heterogeneous databases (ideally). For example, the source could be MySQL, the staging could be Oracle 11g XE, the target could be Oracle 12c EE version 12.1.
In this VM, the single database is Oracle 11g EE version 11.2.0.4.
Two identical copies of Oracle GoldenGate. In this example, the tutorial is using version is 12.1.2.0.0.
One Oracle Data Integrator. In this example, the tutorial is using version is 12.1.3.
Two copies of Java: the one that comes with OGG (for the JAgent), and JDK version 1.7.0_15 or higher for the ODI Agent.
An OS. In this example, the tutorial is using Oracle Enterprise Linux (64-bit) 2.6.32-300.39.5
Optional software to install in Java EE mode (not present in the VM):
One Oracle WebLogic Server 12c. This affects how the ODI Agents are deployed. The VM is not using WLS.

Prerequisites
Before starting this tutorial, you should:
Have access to or have installed Oracle Data Integrator 12c. The prerequisites for that are a FMW home with WLS installed, a database with RCU configured to create the ODI
repositories.
Have access to or have installed sample schemas and repositories. This example uses the ODI_DEMO schema which is available online at: ODI Getting Started. If you are using the VM,
then this schema is already included.

Normally an ODI environment would have two or three hosts. The source database would be on one host (usually the smaller host) and the target database on another host (usually the larger
host). The staging area would be on the more powerful of the two hosts, or possibly on a third host. The configuration used for this demonstration was done on one large host (rather unusual),
so there are some issues with multiple $ORA_HOME definitions that would not normally surface in a "real" environment.

21/10/2014 22:30

ODI+OGG Integration

2 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

If you are using the pre-configured VM, skip to step 1.2.


Depending on your source database technology, the DDL commands will change slightly. To simplify things, the foreign key dependencies will not be enforced at the database level.
1. Create the users and source table.
E-LT Source (OGG Source)

[myuser@myhost ~]$ sqlplus system/oracle


SQL*Plus: Release 11.2.0.4.0 Production on Mon Jul 21 16:40:21 2014
Copyright (c) 1982, 2013, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
SQL > create user odi_demo identified by oracle;
User created.
SQL > create user prod_odi_repo identified by oracle;
User created.
SQL > create user ogg_odi_demo_src identified by oracle;
User created.
SQL > grant DBA to odi_demo, prod_odi_repo, ogg_odi_demo_src;
Grant succeeded.
SQL > set prompt SQL_SOURCE;
SQL_SOURCE > conn odi_demo/oracle
Connected.
SQL_SOURCE > create table SRC_CUSTOMER (
CUSTID
NUMBER(10)
not null,
DEAR
NUMBER(1),
LAST_NAME
VARCHAR2(50),
FIRST_NAME
VARCHAR2(50),
ADDRESS
VARCHAR2(100),
CITY_ID
NUMBER(10),
PHONE
VARCHAR2(50),
AGE
NUMBER(3),
SALES_PERS_ID
NUMBER(10),
constraint PK_SRC_CUSTOMER primary key (CUSTID)
);
Table created.
SQL_SOURCE > conn ogg_odi_demo_src/oracle
Connected.
SQL_SOURCE > create table OGG_CUSTOMER (
CUSTID
NUMBER(10,0)
not null,
DEAR
NUMBER(1,0),
LAST_NAME
VARCHAR2(50),
FIRST_NAME
VARCHAR2(50),
ADDRESS
VARCHAR2(100),
CITY_ID
NUMBER(10,0),
PHONE
VARCHAR2(50),
AGE
NUMBER(3,0),
SALES_PERS_ID
NUMBER(10,0),
constraint PK_OGG_CUSTOMER PRIMARY KEY (CUSTID)
);
Table created.
SQL_SOURCE >

In real life you would also set up foreign key relationships to other tables.
2. Populate the source table. (There is a procedure supplied in the VM to do this any time later in the lab.)

21/10/2014 22:30

ODI+OGG Integration

3 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

E-LT Staging (ODI Source)

SQL_SOURCE > conn odi_demo/oracle


Connected.
SQL_SOURCE >
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (101,'Brendt','Paul',19,107,10,0,'10 Jasper Blvd.','(212) 555 2146');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (102,'McCarthy','Robin',29,11,11,0,'27 Pasadena Drive','(214) 555 3075');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (103,'Travis','Peter',34,12,12,0,'7835 Hartford Drive','(510) 555 4448');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (104,'Larson','Joe',45,13,13,0,'87 Carmel Blvd.','(213) 555 5095');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (105,'Goldschmidt','Tony',55,14,20,0,'91 Torre drive','(619) 555 6529');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (106,'Baker','William',64,15,21,0,'2890 Grant Avenue','(312) 555 7040');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (107,'Swenson','Jack',74,19,22,0,'64 Imagination Drive','(202) 555 8125');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (201,'Sartois','Jean',19,25,30,0,'71 rue Rousseau','79 23 26 23');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (202,'Michaud','Philippe',22,23,31,0,'197 impasse Renoir','78 21 86 20');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (203,'Robert','Christian',38,208,32,0,'1rue Cezanne','42 25 27 29');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (204,'Martin','Christine',42,24,40,1,'12 allee Victor Hugo','25 26 46 26');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (205,'Piaget','Luc',56,29,41,0,'38 allee des Saules','53 42 24 28');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (206,'Gentil','Michele',67,25,11,1,'17montee des Chenes','65 62 26 13');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (207,'Dupont','Marie-Chantale',72,20,50,1,'37 rue Murat','46 72 23 53');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (301,'Edwards','Caroline',18,35,51,1,'68 Downing Street','243867945');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (302,'Marlow','Justin',29,32,52,0,'290 Yorkshire Drive','653643634');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (303,'Wilson','John',34,33,11,0,'28 Sutton Row','158746231');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (304,'McCartney','George',47,34,11,0,'45 Glenthorne Road','323768678');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (305,'Keegan','Hariett',56,35,11,1,'10 Hamilton Park','566344643');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (306,'Jones','Mary',68,36,31,1,'34 Apple Grove','143546456');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (307,'Hopkins','Priscilla',73,38,302,2,'The Gables','634634643');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (401,'Diemers','Erika',18,51,40,2,'Wiesenstrasse 40','235345');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (402,'Schiller','Jurgen',24,52,41,0,'Auf dem Rain 4','142352');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (403,'Durnstein','Adolph',36,53,101,0,'Thomashof 22','745464');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (404,'Weimar','Hans',45,54,50,0,'Goethering 33','346636');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (405,'Schultz','Herbert',59,55,51,0,'Am Holzbach 17','256346');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (406,'Titzman','Silke',63,56,52,0,'Berliner Ring 56','235463');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (407,'Reinman','Heineke',72,55,32,2,'Yorkstrasse 75','234646');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (501,'Arai','Toshihijo',18,70,40,0,'941 Toyota Ave','34784597');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (502,'Kamata','Mariko',24,71,41,0,'70 Kiroto Street','57687462');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (503,'Kamimura','Satoru',38,72,42,0,'34 Kawasaki Avenue','26475684');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (504,'Makino','Tatsuo',45,70,50,0,'2435 Toyota Ave','34413486');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (505,'Mukumoto','Masayuki',59,73,51,0,'59 Yamamoto Blvd','34827691');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (506,'Oneda','Kenji',68,70,52,0,'94 Toyota Blvd','51839463');
insert into SRC_CUSTOMER(CUSTID, LAST_NAME, FIRST_NAME, AGE, CITY_ID, SALES_PERS_ID,
values (507,'Okumura','Isao',74,74,21,0,'3 Toyota Ave','48928371');
COMMIT;

DEAR, ADDRESS, PHONE)


DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)
DEAR, ADDRESS, PHONE)

35 rows created.
SQL_SOURCE > exit

If you want to make sure they worked, you can: SELECT * FROM SRC_CUSTOMER;
The source database is now prepared.

1.2 Prepare Staging database


Normally the source, staging, and target databases would be heterogenous (for example, Oracle and MySQL, Oracle and DB2, or even Oracle EE and Oracle XE, and so on). In this tutorial,
they are all in one large database separated only by schema. Depending on your staging database technology, the DDL commands will change slightly. You cannot reverse engineer a schema
for the database, only for ODI. So you need to redefine the tables here as well. The difference is you do not have to populate them from SQL, you can populate them from ODI as a simple
map.
If you are using the pre-configured VM, skip to step 1.3.
1. Create the staging table. It will be exactly the same as the source table.

21/10/2014 22:30

ODI+OGG Integration

4 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

ODI Staging

[myuser@myhost ~]$ sqlplus odi_demo/oracle


SQL*Plus: Release xx.x.x.x.x Production on Mon dd hh:mm:ss yyyy
SQL > set prompt SQL_STAGE;
SQL_STAGE > create table OGG_CUSTOMER (
CUSTID
NUMBER(10,0)
not null,
DEAR
NUMBER(1,0),
LAST_NAME
VARCHAR2(50),
FIRST_NAME
VARCHAR2(50),
ADDRESS
VARCHAR2(100),
CITY_ID
NUMBER(10,0),
PHONE
VARCHAR2(50),
AGE
NUMBER(3,0),
SALES_PERS_ID NUMBER(10,0),
constraint PK_OGG_CUSTOMER PRIMARY KEY (CUSTID)
);
Table created.
SQL_STAGE > create user odi_staging identified by oracle;
User created.
SQL_STAGE > grant DBA to odi_staging;
Grant succeeded.
SQL_STAGE >

In real life you would also set up foreign key relationships.


The staging database is now prepared.

1.3 Prepare Target database


For the same reason you needed to define the schema on the staging database, you need to define it on the target database as well. Depending on your staging database technology, the DDL
commands will change slightly.
If you are using the pre-configured VM, skip to step 2.1.
1. Create one target table.
E-LT Target (ODI Target)

[myuser@myhost ~]$ sqlplus odi_demo/oracle


SQL*Plus: Release xx.x.x.x.x Production on Mon dd hh:mm:ss yyyy
SQL > set prompt SQL_TARGET;
SQL_TARGET > create table TRG_CUSTOMER (
CUST_ID
NUMERIC(10)
not null,
DEAR
VARCHAR(4),
CUST_NAME
VARCHAR(50),
ADDRESS
VARCHAR(100),
CITY_ID
NUMERIC(10)
not null,
PHONE
VARCHAR(50),
AGE
NUMERIC(3),
AGE_RANGE
VARCHAR(50),
SALES_PERS
VARCHAR(50),
CRE_DATE
DATE,
UPD_DATE
DATE,
constraint PK_TRG_CUSTOMER primary key (CUST_ID)
);
Table created.
SQL_TARGET >

In real life you would also set up foreign key relationships.


The target database is now prepared.

The databases are all prepared.

Normally an OGG environment would have two or more hosts. The source database would be on one host and the target database on another host. The configuration used for this
demonstration was done on one large host (rather unusual), so there are some issues with multiple $OGG_HOME definitions that would not normally surface in a "real" environment. To solve this
on one host, OGG must be completely installed twice, the two instances cannot share any code.

2.1 Prepare Source GoldenGate


How to install OGG is covered in other OBEs. For this demo, the OGG source is the ODI staging database. Configure the source MANAGER and JAGENT processes to talk with ODI.
If you are using the pre-configured VM, skip to step 2.2.
1. Configure (or verify) the source Global commands and GLOBALS file. Edit the file to look like the following view.

21/10/2014 22:30

ODI+OGG Integration

5 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

OGG Source

[myuser@myhost ~]$ cd /home/oracle/Oracle/Middleware/OGG_Source


[myuser@myhost ogg_src]$ ./ggsci
Oracle GoldenGate Command Interpreter for Oracle
Version 12.1.2.0.0 17185003 OGGCORE_12.1.2.0.0_PLATFORMS_130924.1316_FBO
Linux, x64, 64bit (optimized), Oracle 11g on Sep 25 2013 00:31:13
Operating system character set identified as UTF-8.
Copyright (C) 1995, 2013, Oracle and/or its affiliates. All rights reserved.
GGSCI (source) > sh gedit GLOBALS
GGSCI (source) > sh more GLOBALS
--GLOBALS on OGG Source
--Configured by Joe Admin on 1/2/34
EnableMonitoring
GGSCI (source) >

It is a good convention to have comments with the double-dashes as the first few lines in a parameter file. The keywords (for example, EnableMonitoring) are case-insensitive,
so EnableMonitoring is the same as ENABLEMONITORING is the same as enablemonitoring. For readability, you may want to use MixedCase by word.
2. Configure (or verify) the source Manager and mgr.prm file. Edit the file to look like the following view. (You may want to issue the GGSCI command set editor gedit if you don't like
to use vi.)
OGG Source

GGSCI (source) > edit param mgr


GGSCI (source) > view param mgr
--mgr.prm on OGG Source
--Configured by Joe Admin on 1/2/34
Port 7010
GGSCI (source) >

The Port will match the ODI JAgent.


3. Configure (or verify) the source Java Agent and jagent.prm file. Edit the file to look like the following view.
OGG Source

GGSCI (source) > edit param jagent


GGSCI (source) > view param jagent
--jagent.prm on OGG Source
--Configured by Joe Admin on 1/2/34
COMMAND java -Dlog4j.configuration=file:./cfg/log4j.properties -jar -Xms64m -Xmx512m dirjar/jagent.jar
GGSCI (source) >

The source and target jagent.prm files are the same (except for the comments).
4. Configure (or verify) the source JAgent configuration and ./cfg/Config.properties file.
OGG Source

GGSCI (source) > sh gedit ./cfg/Config.properties


GGSCI (source) > sh more ./cfg/Config.properties
####################################################################
## jagent.host: Host name of the machine where jAgent is running ###
## Note: This host name has to be reachable from Monitor Server ###
####################################################################
jagent.host=localhost
jagent.jmx.port=5555
interval.regular=60
interval.quick=30
monitor.host=localhost
monitor.jmx.port=5502
monitor.jmx.username=cmroot
jagent.ssl=false
jagent.username=root
reg.retry.interval=10
instance.query.initial.interval=5
incremental.registration.quiet.interval=5
maximum.message.retrieval=500
jagent.rmi.port=5559
agent.type.enabled=OEM
status.polling.interval=5
message.polling.interval=5
jagent.backward.compatibility=true
GGSCI (source) > exit
[myuser@myhost ogg_src]$

The reason you need to exit GGSCI is so that the new parameters can take effect the next time you start GGSCI.
You also need to DBLogin and then Add TranData for any tables that OGG will extract from. The source GoldenGate instance is now prepared.

2.2. Prepare Target GoldenGate

21/10/2014 22:30

ODI+OGG Integration

6 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

3.1 Prepare ODI Agents


If you are using the pre-configured VM, skip to step 3.1.6.
1. Start ODI Studio. If there is a dekstop icon, click it; otherwise do the following commands:
OGG Target

[myuser@myhost ~]$ cd /home/oracle/Oracle/Middleware/Oracle_Home_1213/odi/studio


[myuser@myhost studio]$ ./odi.sh

The first time takes a while to load.


2. Click Connect to Repository, select ODI and OGG Getting Started. The user is SUPERVISOR and the Password is welcome1. Click

OK

to continue.

The User and Password should be pre-populated.


3. Go to the Topology Navigator tab, and expand

Physical Architecture > Technologies > Oracle GoldenGate, right-click, then New Data Server.

If the OGG_Source and OGG_Target already exist, then open them to verify that they match the screens shown.
4. On the JAgent tab, create (or verify) the OGG_Source JAgent Server.

The RMI Port 5559 should match the value in OGG source Config.properties, the Manager Port 7010 should match the value in OGG source mgr.prm. Save
the New Data Server OGG_Source tab.

and close

5. On the JAgent tab, create (or verify) the OGG_Target JAgent Server.

21/10/2014 22:30

ODI+OGG Integration

7 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

The RMI Port 5561 should match the value in OGG target Config.properties, the Manager Port 7020 should match the value in OGG target mgr.prm. Save
New Data Server OGG_Target tab.

and close the

6. When you are done, it should look like this:

You will come back and test these agents shortly.


The OGG agents are ready from the ODI side.

3.2 Prepare ODI Data Servers


If you are using the pre-configured VM, skip to step 3.2.13.
1. Go to the Topology Navigator tab, and expand

Physical Architecture > Technologies > Oracle, right-click, then New Data Server.

If SRC_ODIDEMO and TRG_ODIDEMO already exist, then open them to verify that they match the screens shown.
2. On the Definition tab, create (or verify) the SRC_ODIDEMO Data Server.

21/10/2014 22:30

ODI+OGG Integration

8 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

3. On the JDBC tab, create (or verify) the JDBC Driver and JDBC URL.

Be careful not to lose the colons between the parameters (they are hard to see...)
4. Test JDBC connectivity by clicking

Click

Test

Test Connection . You will see this pop-up:

to continue.

5. On the Definition tab, create (or verify) the TRG_ODIDEMO Data Server.

The Password is welcome1.


6. On the JDBC tab, create (or verify) the JDBC Driver and JDBC URL.

Be careful not to lose the colons between the parameters (they are hard to see...)
7. Test JDBC connectivity by clicking

Click

Test

Test Connection . You will see this pop-up:

to continue.

21/10/2014 22:30

ODI+OGG Integration

9 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

The Physical Architecture is only half of the Topology definition. You still have to do the Logical Architecture.
9. Go to the Topology Navigator tab, and expand

Logical Architecture > Technologies > Oracle, right-click, then New Logical Schema.

You are going to do this three times for three logical schemas.
10. Create a Logical Schema named ODI_DEMO_SRC with a Context of Global and a Physical Schema of SRC_ODIDEMO.ODI_DEMO as shown.

Save

your work. Close the Logical Schema tab.

11. Create a Logical Schema named ODI_DEMO_TRG with a Context of Global and a Physical Schema of TRG_ODIDEMO.ODI_DEMO as shown.

Save

your work. Close the Logical Schema tab.

12. Create a Logical Schema named OGG_ODI_DEMO_SRC with a Context of Global and a Physical Schema of SRC_ODIDEMO.OGG_ODI_DEMO_SRC as shown.

Save

your work. Close the Logical Schema tab.

13. When you are all done, it should look like this:

21/10/2014 22:30

ODI+OGG Integration

10 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

In the demo VM, all three of these Logical Schemas are on the same database on the same host in the same context. That is very unusual. In real life they would probably be on
different hosts or at least different technologies.
The ODI Data Servers now have physical and logical definitions.

3.3 Prepare ODI Models


If you are using the pre-configured VM, skip to step 3.3.6.
1. Go to the Designer Navigator tab, and expand

Models, click the pull-down and select New Model Folder.

Techncially this is optional, but it is a good convention.


2. Name the folder ODI_DEMO.

The Description is optional. It is a good convention to put the modification history in here. Save

your work. Close the Model Folder tab.

3. Returning to the Designer tab, click the pull-down again and select New Model.

Note that new with ODI version 12.1.3 is the option to do all this on one screen: the New Model and Topology Objects screen.
4. Create the Orders Application model using the parameters shown.

21/10/2014 22:30

ODI+OGG Integration

11 sur 36

Save

your work. Click

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

Reverse Engineer

to read the table metadata. You will see the following pop-up briefly:

5. Create the Sales Administration model using the parameters shown.

Save

your work. Click

Reverse Engineer

to read the table metadata. You will see the following pop-up briefly:

6. The Models should now look like this.

You may have additional datastores (tables) as well. The three datastores that you care about are:

21/10/2014 22:30

ODI+OGG Integration

12 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

The ODI Models and Datastores are now ready to be populated.

3.4 Initial Load of the Staging Table


Populating the Staging table can be done using either the OGG Initial Load or the ODI simple mapping. For simplicity, the tutorial will use the ODI method.
If you are using the pre-configured VM, skip to step 3.4.6. then 3.4.14.
1. Go to the Designer Navigator tab, and expand

Projects, click the pull-down and select New Project.

2. Name the project ODI and OGG Integration Demonstration.

Save

your work. Close the Project folder.

3. Click the pull-down and select New Folder.

You are going to do this twice.


4. Name the folder Initial Load.

Save

your work. Close the folder.

5. Click the pull-down and select New Folder again. Name the folder Sync data.

Save

your work. Close the folder.

6. When you are done, it should look like this:

21/10/2014 22:30

ODI+OGG Integration

13 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

7. Right-click Knowledge Modules, select Import Knowledge Modules.

They may already be present. Check what is already there.


8. Import the following Knowledge Modules (KMs):
CKM Oracle
IKM Oracle Incremental Update
IKM SQL Control Append
JKM Oracle to Oracle Consistent (OGG Online)
You can find them on the VM at /home/oracle/Oracle/Middleware/Oracle_Home_1213/odi/sdk/xml-reference.

You may accidentally import CKM Hive (a known bug), you can safely ignore it.
9. Expand

all the Knowledge Modules, and it should look like this:

Next you will create a mapping to do the initial load of Sales Administration OGG_CUSTOMER table.
10. Right-click Mappings, select .

21/10/2014 22:30

ODI+OGG Integration

14 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

Name the mapping Initial Load Staging.


11. Still on the Designer Navigator tab, expand

Models > ODI_DEMO > Orders Application and also expand

Sales Administration.

a. Drag both OGG_CUSTOMER datastores onto the workspace. Make sure the Orders one is on the left and the Sales one is on the right.
b. Hook the output of the source to the input of the target.
c. Accept Auto Mapping of Attributes.

You can check which OGG_CUSTOMER is which by clicking the title bar and looking at the Properties > General.
12. Select the target OGG_CUSTOMER title bar and change the Target > Integration Type to Control Append.

If it already is Control Append, then just confirm it.


13. Select the Physical tab, then select (indicated by six grey dots) target OGG_CUSTOMER_AP (AP=Access Point, indicated by the added red box). In Properties, change the Loading
Knowledge Module to LKM Oracle to Oracle Pull (DB Link).GLOBAL.

21/10/2014 22:30

ODI+OGG Integration

15 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

If it already is LKM Oracle to Oracle Pull (DB Link).GLOBAL, then just confirm it. Save
14. Click Run

Click

OK

your work, but leave the tab open.

in the top menu bar to run the mapping to populate the table.

on the Run panel. Click

OK

on the Information panel to continue.

15. Go to the Operator Navigator tab, and expand


example is 60, your number may be different.

Session List > Agent > Local > ?? - Initial Load Staging. Make sure that the overall mapping was successful. The "??" on this

21/10/2014 22:30

ODI+OGG Integration

16 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

16. In the Mapping panel, right click on the target datastore.

There are many ways to view the data in the table.


17. Make sure there are 35 rows in the table.

Click

Close

to continue.

18. If you are using the VM, you can use the enclosed ODI and OGG Demo Client to see that two of the three customer tables are populated.

Leave the client running to watch the OGG+ODI changes. Remember:


Source: OGG_CUSTOMER (Orders App model)
Staging: OGG_CUSTOMER (Sales Admin model)
T
t
(S l Ad i
d l)

21/10/2014 22:30

ODI+OGG Integration

17 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

3.5 Initial Load of the Target Table


Populating the Target table is more complex than the Staging table because it has a different structure: it has built-in foreign key (FK) references (e.g. CITY_ID) as well as column
transformations (e.g. CUST_NAME=FIRST_NAME||LAST_NAME). For simplicity, the tutorial will assume you have the VM and can run the pre-existing mappings and procedures.
If you are not using the pre-configured VM, then your tables do not have the FK references and you can do a simple mapping of some of the attributes (and others will just have to go blank for
this demo).
1. Go to the Designer Navigator tab, and expand Load Plans and Scenarios, select LOAD_REFERENCE_DATA Version 001. Click Run
populate the referenced tables such as TRG_CITY.

2. Click

OK

on the Run panel. Click

OK

in the top menu bar to run the mapping to

on the Information panel to continue.

3. Go to the Operator Navigator tab, click Refresh


. Expand Session List > Agent > Local > ?? - LOAD_REFERENCE_DATA. Make sure that the overall mapping was successful.
The "??" on this example is 50, your number may be different.

Even though the overall success was Warning


4. Go to the Designer Navigator tab, and expand
populate the target table TRG_CUSTOMER.

, the individual elements were all successful

Projects > Sync Data > Mappings, then select Load TRG_CUSTOMER. Click Run

in the top menu bar to run the mapping to

21/10/2014 22:30

ODI+OGG Integration

18 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

Notice this Physical Mapping Design: Bulk Load, whereas the previous one was Physical Mapping Design: Physical.
. Expand Session List > Agent > Local > ?? - Load TRG_CUSTOMER_Bulk Load. Make sure that the overall mapping was
6. Go to the Operator Navigator tab, click Refresh
successful. The "??" on this example is 62, your number may be different.

Even though the overall success was Warning

, the individual elements were all successful

7. Use SQL*Plus or the enclosed ODI and OGG Demo Client to see that all three customer tables are populated.

Note that CUST_NAME is concatenated from FIRST_NAME||UPPER(LAST_NAME), and DEAR is resolved into Mr., Mrs., and so on. Also, a few of the rows are missing from the
target: 203, 207, and so on.
The initial load of the Target table is complete.

The ODI environment is prepared.

ODI communicates with OGG via agents. The agents are defined by keywords in an ASCII text file. ODI configures an extract, datapump, and replicat via the Studio GUI. This creates the text
files mentioned previously. ODI places the text files in their proper OGG directories.

4.1 Configure OGG Extract and Datapump via ODI


If you are using the pre-configured VM, skip to step 4.1.3.
1. Go to the Topology Navigator tab, and expand

Physical Architecture > Technologies Double-click Oracle GoldenGate.

21/10/2014 22:30

ODI+OGG Integration

19 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

There are lots of options you can configure, but the most important is Technology Type: ODI Connector.
2. Expand Oracle GoldenGate > OGG_Source, then open (double-click) CAP (capture, also known as extract). The difference between CAP and CAP_IL is the "_IL" suffix stands for
"Initial Load." This demonstration uses an ODI mapping rather than OGG's _IL here to do the initial load. You can use either one.

Note the Trail File Paths and file suffixes you pick, such as oc (odi capture) and op (odi pump).
3. Expand

Logical Architecture > Technologies > Oracle GoldenGate, and open (double-click) CAP_LS (abbreviation for CAPture Logical Schema). It should look ike this:

This matches the Physical Architecture.


The OGG extract (CAPture) and datapump (DELivery) are now configured as both physical and logical entities.

21/10/2014 22:30

ODI+OGG Integration

20 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

4.3 Start OGG Processes via GGSCI

Change Data Capture (CDC) is configured with a Journalizing Knowledge Module (JKM). You define it for a model by adding subscribers, and then start it for a datastore. The transfer from the
Journal to a mapping is handled by a package in a loop.

5.1 Configure ODI Change Data Capture (CDC)


If you are using the pre-configured VM, you still need to do this whole section.
1. Go to the Designer Navigator tab, and expand

Models > ODI_DEMO. open (double-click) Orders Application.

2. Select the Journalizing tab. Note that the JKM is at the Model level, not the datastore level.

The Journalizing Mode: Consistent Set matches the JKM Oracle to Oracle Consistent. The (OGG Online) means that the ODI-created OGG parameter files are placed into
the OGG directories automatically rather than having to be copied manually.
The difference between CAP and CAP_IL is the "_IL" suffix stands for "Initial Load." This demonstration uses an ODI mapping rather than OGG's _IL here to do the initial load.
You can use either one.
3. Back on the Designer Navigator tab, right-click Orders Application, and select Changed Data Capture > Add to CDC.

21/10/2014 22:30

ODI+OGG Integration

21 sur 36

4. Click

Yes

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

to close the Question window.

5. Right-click Orders Application, and select Changed Data Capture > Subscriber > Subscribe.

A subscriber is an alias representing a process that is interested in changed data. Since you can have multiple processes interested in the same changed data, you can define
multiple subscribers. Each subscriber can move the changed data when needed without impacting the other ones.
6. In the List of Subscribers to Add, enter ODIDEMO.

Click the green plus to add the name to the list.

Click

OK

to continue.

7. This starts a session that creates the journalizing environment and adds the user.

21/10/2014 22:30

ODI+OGG Integration

22 sur 36

Click

OK

to continue. This takes a few seconds to complete.

Click

OK

to continue.

8. Go to the Operator Navigator tab, and click Refresh


. Expand
"??" on this example is 63, your number may be different.

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

Session List > Agent > Local > ?? - Orders Application. Make sure that the overall mapping was successful. The

9. Back on the Designer Navigator tab, right-click Orders Application, and select Changed Data Capture > Start Journal.

This starts a session that starts the journalizing environment. This is where the OGG CAPture and DELivery processes and parameter files are actually run. Confirm the Run and
Information pop-ups as you did in the previous step 7.
10. Go to the Operator Navigator tab, and click Refresh
. Expand
"??" on this example is 64, your number may be different.

Session List > Agent > Local > ?? - Orders Application. Make sure that the overall mapping was successful. The

21/10/2014 22:30

ODI+OGG Integration

23 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

The warnings
you may see are the tasks that were already completed in the previous step 8. For example, the Operator is telling you on line 5 that you cannot "create" a
subscribers table because there already is one. You can ignore all of the warnings here.
11. Depending on how you have your preferences set, you may or may not see a change in the icon for the datastore. If you want to see the icon indicating CDC activity, go to the main
(top) tool bar and click Tools > Preferences, then expand ODI > User Interface > Designer. Select Show the CDC Modifications in the tree.

Click

OK

to continue.

12. If you go back to the Designer tab, and expand

Models > ODI_DEMO > Orders Application, you may see a very tiny change on the icon: a yellow clock face.

21/10/2014 22:30

ODI+OGG Integration

24 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

If the clock is yellow, that indicates waiting; a green clock indicates something else.
ODI CDC is now configured and started.

5.2 Configure ODI Mappings


If you are using the pre-configured VM, you still need to do this whole section. It is mostly just looking at parameters.
1. Go to the Designer Navigator tab, and expand Projects > Sync Data > Mappings, then open (double-click) Load TRG_CUSTOMER. Select OGG_CUSTOMER and notice that the
Properties > Journalizing filter is for the subscriber you configured earlier: ODIDEMO.

Note that OGG_CUSTOMER used in this Mapping is coming from the Orders Applications source model. It is the actual source table and not the replicated copy used by OGG
(located in the Sales Administration model). ODI will transparently know which table to use based on the Journalizing settings of the Mapping.
2. Click the Physical tab. Click Trickle Feed to display the incremental load Physical Design.

Two deployment specifications have been created in this environment:


Bulk Load:
Does a bulk insert into TRG_CUSTOMER and was previously used to perform an initial load of the target table.
Trickle Feed:
Performs an incremental load of TRG_CUSTOMER using the changed data coming from OGG.
3. Select OGG_CUSTOMER. Notice that the Properties > General > Journalized Data Only is selected.

21/10/2014 22:30

ODI+OGG Integration

25 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

Even though the mapping says to use the source model, selecting Journalized Data Only causes ODI to use the target journal of only changed records.
The mapping has the power to do a transformation. That is why OGG alone is not a complete solution, you also need ODI.

5.3 Configure ODI Packages


Since ODI is inherently a batch system, to make it do a continuous delivery of changed records requires some kind of infinite loop. The way to do that is with a package.
1. Go to the Designer Navigator tab, and expand

Projects > Sync Data > Packages, then open Sync Data.

This package will run continuously. This package will wait for new changes to be replicated by OGG and upon detection it will move and transform the replicated data from the
staging table into the target table using ODI.
2. The ODI Tool step Wait for Changes is doing the CDC detection using OdiWaitForLogData. It is waiting for some changed records to be published by OGG.

21/10/2014 22:30

ODI+OGG Integration

26 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

Parameters of Note:
Global Row Count=1 says to only wait for one row to be changed before proceeding to the next step (i.e., a "micro-batch").
Polling Interval=1000 milliseconds, i.e., 1 second (basically near-real-time).
Logical Schema=ODI_DEMO_TRG and Subscriber=ODIDEMO match previous configuration values.

3. Once the detection of one changed row is successful, the next package step Extend and Lock will logically lock the records that will be moved for your ODIDEMO subscriber. "Locking"
is what makes this a Consistent Journalizing set versus a Simple set.

Parameters of Note:
Subscribers=ODIDEMO match previous configuration values.
Consumption=Extend, Lock. This second step does the first two Consumption options; the fourth step does the last two Consumption options.

4. The Mapping Load TRG_CUSTOMER will load the changed data using the Trickle Feed physical design and the ODIDEMO Subscriber

21/10/2014 22:30

ODI+OGG Integration

27 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

It would be a good practice to have an unsuccessful path ("ko" red arrow) to trap possible errors.
5. This is the opposite of package step 2, "Extend and Lock."

Parameters of Note:
Subscribers=ODIDEMO match previous configuration values.
Consumption=Purge, Unlock. The second step does the first two Consumption options; this fourth step does the last two Consumption options.

6. The Package ends with a step executing a Scenario, the same scenario, recursively.

21/10/2014 22:30

ODI+OGG Integration

28 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

It allows essentially looping through the same Package creating a new Session for every execution. This is a best practice rather than creating the loop directly in the Package as
this allows you to better control the overall execution.
7. Go to the Designer Navigator tab, and expand
journaling data to the target table.

Click

OK

on the Run panel. Click

OK

Projects > Sync Data > Packages, then select Sync Data. Click Run

in the top menu bar to run the package to move the CDC

on the Information panel to continue.

8. Go to the Operator Navigator tab, click Refresh


. Expand
"??" on this example is 65, your number may be different.

Session List > Agent > Local > ?? - Sync Data. Make sure that the package is running/waiting (green arrow

). The

Since it is a continuous loop, it is not "finished" with this session.


The ODI package is now configured and running in an infinite loop, waiting for records to deliver.

Now all the pieces are in place. Check what the ODI and OGG status looks like before anything has changed, then start changing data, and observe what changes.

6.1 Check BEFORE views of OGG processes and the tables


1. Make sure the OGG Source Extract (CAPture) and Data Pump (DELivery) are created and Status=RUNNING.

21/10/2014 22:30

ODI+OGG Integration

29 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

OGG Source

GGSCI (source) > Info All


Program
MANAGER
JAGENT
EXTRACT
EXTRACT

Status
RUNNING
RUNNING
RUNNING
RUNNING

Group

Lag at Chkpt

Time Since Chkpt

CAP
DELP

00:00:00
00:00:00

00:00:00
00:00:05

GGSCI (source) >

These were created by ODI. If you are curious, you can do:
GGSCI > View Param CAP
GGSCI > View Param DELP

to see what was created.


2. Make sure the OGG Target Replicat (DELivery) is created and Status=RUNNING.
OGG Target

GGSCI (target) > Info All


Program
MANAGER
JAGENT
REPLICAT

Status
RUNNING
RUNNING
RUNNING

Group

Lag at Chkpt

Time Since Chkpt

DEL1

00:00:00

00:00:01

GGSCI (target) >

3. You can verify the contents of the tables with SQL*Plus, SQL Developer, or the Demo Client.

Note that customer 104 has a first name of Joe. It says so in all three tables.
Now you have seen what the processes and data looks like before anything has changed.

6.2 Do DML on source data


Do inserts, updates, and deletes on the OGG_ODI_DEMO_SRC.OGG_CUSTOMER source data, and watch it propagate through the system.
1. Change the first name of customer 104 to Harry.

21/10/2014 22:30

ODI+OGG Integration

30 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

2. Nothing to do here, but watch carefully because it changes quickly!

Now the Staging says Harry.


3. Nothing to do here, but watch carefully because it changes quickly!

Now the Target says Harry.


The changes have replicated through OGG and then ODI CDC.

6.3 Check OGG processes


Sometimes DML breaks the OGG processes if they were mis-configured. Check thier Status.
1. Make sure the OGG Source is still running.
OGG Source

GGSCI (source) > !


info all
Program
MANAGER
JAGENT
EXTRACT
EXTRACT

Status
RUNNING
RUNNING
RUNNING
RUNNING

Group

Lag at Chkpt

Time Since Chkpt

CAP
DELP

00:00:00
00:00:00

00:00:00
00:00:06

GGSCI (ODIGettingStarted) 12> Stats cap


Sending STATS request to EXTRACT CAP ...
Start of Statistics at 2014-07-29 14:18:59.
Output to /home/oracle/Oracle/Middleware/OGG_Source/dirdat/oc:
Extracting from OGG_ODI_DEMO_SRC.OGG_CUSTOMER to OGG_ODI_DEMO_SRC.OGG_CUSTOMER:
*** Total statistics since 2014-07-29 14:00:52 ***
Total inserts
Total updates
Total deletes
Total discards
Total operations

0.00
3.00
0.00
0.00
3.00

(...many lines omitted for clarity...)


GGSCI (source) >

21/10/2014 22:30

ODI+OGG Integration

31 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

2. Make sure the OGG Target is still running.


OGG Target

GGSCI (target) > !


info all
Program
MANAGER
JAGENT
REPLICAT

Status
RUNNING
RUNNING
RUNNING

Group

Lag at Chkpt

Time Since Chkpt

DEL1

00:00:00

00:00:07

GGSCI (ODIGettingStarted) 8> Stats del1


Sending STATS request to REPLICAT DEL1 ...
Start of Statistics at 2014-07-29 14:19:32.
Replicating from OGG_ODI_DEMO_SRC.OGG_CUSTOMER to ODI_DEMO.OGG_CUSTOMER:
*** Total statistics since 2014-07-29 14:00:58 ***
Total inserts
Total updates
Total deletes
Total discards
Total operations

0.00
3.00
0.00
0.00
3.00

(...many lines omitted for clarity...)


GGSCI (target) >

Even though the ODI CDC creates many sessions (micro-batches of 1 record each), OGG is just one big session.
The OGG processes are still running, waiting for more changes.

6.4 Check AFTER views of the tables


1. Note that EACH row changed in OGG_CUSTOMER creates a separate session (this behavior can be changed). The current session is always running/waiting, the previous sessions are
completed.

You can see the five steps (numbered 0-4) of the SYNC_DATA package for each session.
2. If you want, you can check the OGG reports:
OGG Source

GGSCI (source) > View Report CAP


***********************************************************************
Oracle GoldenGate Capture for Oracle
Version 12.1.2.0.0 17185003 OGGCORE_12.1.2.0.0_PLATFORMS_130924.1316_FBO
Linux, x64, 64bit (optimized), Oracle 11g on Sep 25 2013 00:44:16
Copyright (C) 1995, 2013, Oracle and/or its affiliates. All rights reserved.
Starting at 2014-07-28 12:04:06
***********************************************************************
Operating System Version:
Linux
Version #1 SMP Fri Feb 22 18:16:18 PST 2013, Release 2.6.39-400.17.1.el6uek.x86_64
Node: ODIGettingStarted
Machine: x86_64
soft limit
hard limit
Address Space Size
:
unlimited
unlimited
Heap Size
:
unlimited
unlimited
File Size
:
unlimited
unlimited
CPU Time
:
unlimited
unlimited
Process id: 22568
Description:
***********************************************************************
**
Running with the following parameters
**
***********************************************************************
(...many lines omitted for clarity...)
GGSCI (source) >

21/10/2014 22:30

ODI+OGG Integration

32 sur 36

3. Go to the Designer Navigator tab, and expand

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

Models > ODI_DEMO > Orders Application. Right-click OGG_CUSTOMER and select Changed Data Capture > Journal Data.

This is not very interesting because no data shows up at this time! Had there not been a consumer, then the Journal would have the three prepended fields of Journal Flag
(Insert/Update/Delete), Date, and Subscriber, then the full row of new data for the table being captured. As it is, the data is in this journal for less than a second before being
consumed.
4. If you want to inspect the data with SQL*Plus, do the following queries:
E-LT Source (OGG Source)

[myuser@myhost ~]$ sqlplus system/oracle


SQL*Plus: Release xx.x.x.x.x Production on Mon dd hh:mm:ss yyyy
SQL_SOURCE > select custid, last_name, first_name
from OGG_ODI_DEMO_SRC.OGG_CUSTOMER where custid=104;
CUSTID LAST_NAME
FIRST_NAME
---------- -------------------- -------------------104 Larson
Harry

The above is for the source table.


E-LT Staging (OGG Target, ODI Source)

[myuser@myhost ~]$ sqlplus system/oracle


SQL*Plus: Release xx.x.x.x.x Production on Mon dd hh:mm:ss yyyy
SQL_STAGING > select custid, last_name, first_name
from ODI_DEMO.OGG_CUSTOMER where custid=104;
CUSTID LAST_NAME
FIRST_NAME
---------- -------------------- -------------------104 Larson
Harry

The above is for the staging table.


E-LT Target (ODI Target)

[myuser@myhost ~]$ sqlplus system/oracle


SQL*Plus: Release xx.x.x.x.x Production on Mon dd hh:mm:ss yyyy
SQL_TARGET > select custid, last_name, first_name
from ODI_DEMO.TRG_CUSTOMER where custid=104;
CUSTID LAST_NAME
FIRST_NAME
---------- -------------------- -------------------104 Larson
Harry

The above is for the target table. All three should be the same, with a first name of Harry.
If the ODI side seems inefficient, you can always change the batch size to be increased from the current value of 1 to something larger, for example, 10.

21/10/2014 22:30

ODI+OGG Integration

33 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

At this point the OGG replication and the ODI CDC will continue to run/wait indefinitely (barring any error conditions). If you ever wish to stop it gracefully, perform the following steps:

7.1 Cleanup ODI


1. Go to the Operator Navigator tab, click Refresh
. Expand Session List > Agent > Local. Right-click the top-most ?? - Sync Data. Make sure that the package is running/waiting
. (The "??" on this example is 68, your number may be different.) Click Stop Immediate.
with a green arrow

This stops the package abruptly, breaking out of the infinite loop.

Click

OK

to continue. It will show the package session as failing

. That is normal in this kind of a stop.

2. You do not have to remove the objects from CDC, at this point they are stopped. if you did want to completely clean up, then you go through the same steps to remove from CDC as you
did to add it, only in reverse order. The order is important. You can do it at the datastore level or the model level. For the datastore: First drop the journal.

This causes a session to start. Confirm in the usual way.


3. Optionally you could have dropped the journals for all datastores in the model. Same process as for a datastore, only one level up.

21/10/2014 22:30

ODI+OGG Integration

34 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

This causes a session to start. Confirm in the usual way.


4. Like the journal, you can remove an object from CDC at the datastore level or at the model level. For the datastore, remove it from the CDC.

The question prompts you, "Are you sure?"

Click

Yes

to continue.

21/10/2014 22:30

ODI+OGG Integration

35 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

The question prompts you, "Are you sure?"

Click

Yes

to continue.

All objects have been removed from CDC. The tiny yellow clock icon should have been removed as well from the OGG_CUSTOMER label in the Models list.

7.2 Cleanup OGG


Removing the models from the CDC on ODI will cause the OGG extract, datapump, and replicat processes to be stopped and removed. There is nothing more you need to do manually.
1. On the OGG source, note that the extract and datapump processes are stopped and removed (unregistered), but the parameter files persist. The manager and agents are left running.
OGG Source

GGSCI (source) > Info All


Program
MANAGER
JAGENT

Status
RUNNING
RUNNING

Group

Lag at Chkpt

Time Since Chkpt

GGSCI (source) > View Param cap


extract CAP
userid ODI_STAGING, password oracle
exttrail /home/oracle/Oracle/Middleware/OGG_Source/dirdat/oc
TABLE OGG_ODI_DEMO_SRC.OGG_CUSTOMER;
GGSCI (source) >

Note that the password is in clear text. You may want to change that to an alias if you have OGG version 12.1.2 or higher.
2. On the OGG target, note that the replicat process is stopped and removed (unregistered), but the parameter file persists.

21/10/2014 22:30

ODI+OGG Integration

36 sur 36

http://www.oracle.com/webfolder/technetwork/tutorials/obe/fmw/odi/o...

OGG Target

GGSCI (target) > Info All


Program
MANAGER
JAGENT

Status
RUNNING
RUNNING

Group

Lag at Chkpt

Time Since Chkpt

GGSCI (target) > View Param del1


replicat DEL1
userid ODI_STAGING, password oracle
discardfile , purge
sourcedefs /home/oracle/Oracle/Middleware/OGG_Target/dirdef/CAP.def
map OGG_ODI_DEMO_SRC.OGG_CUSTOMER, TARGET ODI_DEMO.OGG_CUSTOMER, KEYCOLS (CUSTID);
map OGG_ODI_DEMO_SRC.OGG_CUSTOMER, target ODI_STAGING.J$OGG_CUSTOMER, KEYCOLS (CUSTID, WINDOW_ID),
LRECORDS, OVERRIDEDUPS,
COLMAP (
CUSTID = CUSTID,

INSERTAL

WINDOW_ID = @STRCAT(@GETENV('RECORD', 'FILESEQNO'), @STRNUM(@GETENV('RECORD', 'FILERBA'), RIGHTZERO, 10))


);
GGSCI (target) >

Note that the password is in clear text. You may want to change that to an alias if you have OGG version 12.1.2 or higher.
It might be a good idea to View Report CAP (the completed report) just to make sure that nothing unusual is in there.

Following the business scenario posed in the Introduction section, you had three databases (actually one database with three schemas): a source, staging, and target database being used for
E-LT. OGG was used to make an exact replicate of the OGG_CUSTOMER table, from schema OGG_ODI_DEMO_SRC on the source to schema ODI_DEMO on the staging database. Then ODI was
used to make a transformation from OGG_CUSTOMER table to TRG_CUSTOMER table, changing some columns on the fly. ODI was copying only changed (inserted, updated, or deleted) rows in
micro-batches of 1 every 1 second.
In this tutorial, you learned to:
Prepare an Oracle Database for ODI and OGG replication
Prepare ODI for CDC
Prepare OGG for replication
Start, Monitor, Stop ODI and OGG integration

Resources
Here is a list of conceptual or procedural Help topics relevant to this tutorial:
ODI 12c full Documentation online (includes past versions).
ODI 12c and OGG Integration Documentation .
ODI 12c and OGG Webcast, specifically Integration.
Specific courses where ODI is discussed in detail:
[D82167GC10] "Oracle Data Integrator 12c: Integration and Administration"
[D82171GC10] "Oracle Data Integrator 12c: New Features"
[DxxxxxGC10] "Oracle Data Integrator 12c: Advanced Integration and Development"
[D78191GC10] "Oracle Data Integrator 11g: Advanced Integration and Development"
Specific courses where OGG is discussed in detail:
[D84357GC10] "Oracle GoldenGate 12c: Fundamentals for Oracle"
[D76689GC10] "Oracle GoldenGate 11g: Advanced Configuration for Oracle"
External Web sites for related information: A-Team Blogs
To learn more about ODI and OGG, refer to additional OBEs in the free Oracle Learning Library:
A long list of ODI general OBEs here.
Here is the same ODI+OGG tutorial but for ODI 11g.

Credits
Lead Curriculum Developer: Steve Friedberg
Other Contributors: Julien Testut, Product Manager; Alex Kotopoulis, Product Manager, Tom Mangiacapre.

21/10/2014 22:30

Vous aimerez peut-être aussi