Wednesday, 13 July 2016

Setup unixODBC for oracle database instance to connect DB2 database

Set up unixODBC to connect DB2 database on Oracle database

A. Installation driver:

1. Unzipping and extracting
unixodbc: 
Download from: http://www.unixodbc.org/download.html

gzip -d unixODBC-2.3.2.tar.gz
tar xf unixODBC-2.3.2.tar

DB2 client:
Download from: http://www-01.ibm.com/support/docview.wss?uid=swg24034634

gzip -d v9.7fp8_hpipf64_odbc_cli.tar.gz
tar xf v9.7fp8_hpipf64_odbc_cli.tar

2. Change Directory
 cd unixODBC-2.3.2

3. Set PATH and Compiler flags

PATH=$PATH:/usr/ccs/bin;export PATH
PATH=$PATH:/usr/sbin;export PATH
CXXFLAGS=+DD64;export CPPFLAGS
CFLAGS=+DD64;export CFLAGS

4. Configure, compliing and installing
   ./configure --prefix=/u01/app/oraodbc/unixODBC-2.3.2 --enable-gui=no --enable-drivers=no
   make
   make install

5. Confgiure the db2 odbc client:
Location: /u01/app/oraodbc/db2_odbc_client/odbc_cli/clidriver/cfg
File: db2cli.ini

[DB2]
database=
protocol=TCPIP
hostname=
servicename=
BitData=1
BlockLobs=1
SQLCODEMAP=1

6. Configure the odbc ini:
Location: /u01/app/oraodbc/unixODBC-2.3.2/etc/
File: odbc.ini
Location: /u01/app/oracle/product/11.2.0/dbhome_1
File: .odbc.ini
Add to odbc.ini and .odbc.ini 
   [ODBC Data Sources]
   DB2=IBM DB2 ODBC DRIVER

   [DB2]
   Driver=/u01/app/oraodbc/db2_odbc_client/odbc_cli_o/odbc_cli/clidriver/lib/libdb2o.so
   AUTHENTICATION=SERVER
   SECURITY=SSL
   CHARSET=AMERICAN_AMERICA.WE8MSWIN1252

7. Create ora file for Oracle HS (e.g. inidb2.ora)
Location: /u01/app/oracle/product/11.2.0/dbhome_1/hs/admin
# This is a sample agent init file that contains the HS parameters that are
# needed for the Database Gateway for ODBC

#
# HS init parameters
#
HS_FDS_CONNECT_INFO = DB2
HS_FDS_TRACE_LEVEL = DEBUG
HS_FDS_SHAREABLE_NAME = /u01/app/oraodbc/unixODBC-2.3.2/lib/libodbc.so
HS_FDS_SQLLEN_INTERPRETATION=64
HS_FDS_TIMESTAMP_MAPPING="TIMESTAMP(6)"
HS_FDS_DATE_MAPPING=CHAR
# fixed triple size problem
HS_KEEP_REMOTE_COLUMN_SIZE=ALL
HS_FDS_SUPPORT_STATISTICS=FALSE
#HS_LANGUAGE=AMERICAN_AMERICA.AL32UTF8
HS_LANGUAGE=AMERICAN_AMERICA.WE8MSWIN1252
HS_FDS_REMOTE_DB_CHARSET=AMERICAN_AMERICA.AL32UTF8
HS_NLS_NCHAR=AL16UTF16

#
# ODBC specific environment variables
#
set ODBCINI=/u01/app/oraodbc/unixODBC-2.3.2/etc/odbc.ini


# Environment variables required for the non-Oracle system
#
#set DB2INSTANCE=db2inst1
set DELIMIDENT=y


8. Update listener.ora and tnsnames.ora
Location: /u01/app/oracle/product/11.2.0/dbhome_1/network/admin
Add to listener.ora 

SID_LIST_LISTENER1521=
      (SID_LIST=
        (SID_DESC=
          (SID_NAME=DB2)
          (ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1)    
          (ENVS=LD_LIBRARY_PATH64=/u01/app/oracle/product/11.2.0/dbhome_1/hs/lib:/u01/app/oraodbc/db2_odbc_client/odbc_cli_o/odbc_cli/clidriver/lib:/u01/app/oracle/product/11.2.0/dbhome_1/lib)
          (PROGRAM=dg4odbc)
        )

Add to tsnames.ora 

DG4ODBC_DB2_SSL =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = host001)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SID = DB2)
    )
    (HS=OK)
  )

9. Reload Listener
lsnrctl status
lsnrctl reload

10. Create DBLINK
 create database link DBLINK_ODBC_DB2
 connect to ibmdb2user identified by *******
 using 'DG4ODBC_DB2_SSL';

11. Testing the connection:
 select * from user.table01@DBLINK_ODBC_DB2;


B. SSL Configuration:

Reference:
http://pic.dhe.ibm.com/infocenter/db2luw/v9r7/topic/com.ibm.db2.luw.admin.sec.doc/doc/t0053518.html

1. Download GSKit Package from IBM

Note: 
1. The GSKit is not free for download from IBM sites and it required use root to install.

Install GSKit 8 Scripts:
http://www-01.ibm.com/support/docview.wss?uid=swg21628888 

Operation Steps : HP-UX - Install Instructions for GSKit 8

1. Extract the file
==> cd
==> gunzip -c DB2_SF_SSL_10_HP-UX_IA64.tar.gz | tar -xf –

2. The contents of the folder:
==> cd gskit/hpipf64/
./hpipf64:
gskcrypt64-8.0.14.14.hpux.ia64.tar.Z
gskssl64-8.0.14.14.hpux.ia64.tar.Z

Description of the files:

For TDS 64 bit Client components:
Global Security Kit V8.r.m.f for HPUX IA 64-bit Crypto - gskcrypt64-8.r.m.f.hpux.ia64.tar.Z
Global Security Kit V8.r.m.f for HPUX IA 64-bit - gskssl64-8.r.m.f.hpux.ia64.tar.Z

Note: r.m.f are release, maintenance and fix level of GSKit V8.
3. Now extract individual package files:
==> uncompress gsk*Z
==> tar -xf gskcrypt64*.tar
==> tar -xf gskssl64*.tar
==> ls -1d gsk*64 # the following output will be seen
gskcrypt64
gskssl64
      
4. Install the packages:

For 64 bit GSKit: (From the 64 subfolder where you can see the listing of gskssl64 and gskcrypt64)
==> cd 8*-TIV-GSKIT-HPUXIA64-*/64 # this full path becomes $PWD and is set in most shells.
==> ls -1d gsk*64
gskcrypt64
gskssl64

==> swinstall -s $PWD/gskcrypt64 gskcrypt64
==> swinstall -s $PWD/gskssl64 gskssl64
      
5. Verify the installed fileset levels:
==> swlist | egrep "gskcrypt|gskssl"


2. Upload ".arm" key to db server (E.g. "/u01/app/oraodbc/keystore")

3. Set PATH

PATH=$PATH:/bin:/lib;export PATH
echo $PATH

4. Create key database under keystore folder
Location: /u01/app/oraodbc/keystore
client key database name: ibmdb2db.kdb
gsk8capicmd_64 -keydb -create -db "keystore db name" -pw "keystore password" -stash

5. Import server certificate to the client key database
client key database name: ibmdb2db.kdb
server certificate: serverdb2.arm
 gsk8capicmd_64 -cert -add -db "keystore db name" -pw "keystore password" -label "dbselfsigned" -file "" -format ascii -fips

– Note:
For example, the following command creates a key database called mydbclient.kdb and a stash file called mydbclient.sth -stash:
gsk8capicmd_64 -keydb -create -db "mydbclient.kdb" -pw "mydbclientpw0"
The -stash option creates a stash file at the same path as the key database, with a file extension of .sth. At connect time, GSKit uses the stash file to obtain the password to the key database.


6. update the db2 odbc client config (red color):
Location: /u01/app/oraodbc/db2_odbc_client/odbc_cli/clidriver/cfg
File: db2cli.ini
[DB2]
database=
protocol=TCPIP
hostname=
servicename=
security=ssl
ssl_client_keystoredb=/u01/app/oraodbc/keystore/ibmdb2db.kdb
ssl_client_keystash=/u01/app/oraodbc/keystore/ibmdb2db.sth

7. Reload Listener
lsnrctl status
lsnrctl reload


Enjoy =)

No comments:

Post a Comment