On installing Oracle Database on UNIX

There are mainly 2 ways to install software on UNIX:
– either installation media constains the source code and the installation process will compile this source code, link it and copy the generated binaries to the right Unix directories.
– or installation media contains only the binaries and the installation process will copy these binaries to the right directories.

Overall installation process

What does the Oracle Universal Installer (OUI) do when installing Oracle Database on UNIX ? Oracle Database is a closed source software: code source is not in the installation media. Actually OUI does more than copying binaries to Oracle Home directory. The main UNIX steps are:

1. checking operating system prerequisites especially required software (RPM on Linux for example) that will be used during the linking steps
2. copying object code to Oracle Home
3. linking object code to first build libraries especially in $ORACLE_HOME/lib and then executables
4.updating Oracle inventory that registers all Oracle software installations on current machine
5. running some setup and configuration assistants.

The linking step

The installation media contains object code that is not ready to be run because this object code must be first linked with operating system libraries on the target machine: executables like sqlplus (SQL*Plus), lnsrctl (Oracle Net Listener Control utility), rman (Recovery Manager command line tool), tnslsnr (Oracle Net listener) and oracle (the unique executable for all background and dedicated or shared server processes of an Oracle instance) will be created during this linking step.

If you install Oracle software in graphical mode OUI will always display the corresponding step. You can find messages in the corresponding OUI log created in Oracle inventory logs directory. For example linking steps for installation on Oracle Linux 6.4 can be found with grep command against installActionsXXX.log. The detailed link steps are logged in $ORACLE_HOME/install/make.log. Note that orald on Linux is only a wrapper script for GCC:

$ cat/u01/app/
# $Header: buildtools/port/orald /linuxamd64/3 2012/10/02 19:28:56 ekarichk Exp $
# orald
# Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
#   NAME
#     orald - Wrapper to invoke ld
#     Invokes ld to link binaries and shared libraries against Intel
#     runtime and runtime libraries.
#     Emulates some of the gcc command line options, in particular, -Wl,xxx
#     can be used to pass an option to ld.
#   ekarichk    09/28/12 - bug/14692807: pull out crt*
#   ekarichk    09/04/12 - bug/13517928: use ld for linking
#   ekarichk    01/18/12 - Creation


# Just use CC for now
exec ${CC} "$@"

exit 1

Statically linked and dynamically linked code

If an UNIX executable is statically linked it means that object code is incorporated in the executable file. If an UNIX executable is dynamically linked it means that object code is not incorporated in the executable but loaded in memory at executable start-up from shared libraries. For more details please read Linux Program Library HOWTO.

Although Oracle binaries have a lot of statically linked code they are also using shared libraries. You can used the ldd UNIX command to list shared libraries for any executable on UNIX. For example on Linux 6.4 x86_64 with Oracle you can see that the oracle executable is using some Oracle shared libraries from $ORACLE_HOME/lib and some OS shared libraries from /lib64:

$ ldd /u01/app/
        linux-vdso.so.1 =>  (0x00007fffff159000)
        libodm12.so => /u01/app/ (0x00007f687876b000)
        libcell12.so => /u01/app/ (0x00007f68784b0000)
        libskgxp12.so => /u01/app/ (0x00007f68781af000)
        libskjcx12.so => /u01/app/ (0x00007f6877f6c000)
        librt.so.1 => /lib64/librt.so.1 (0x000000360e400000)
        libmql1.so => /u01/app/ (0x00007f6877ceb000)
        libipc1.so => /u01/app/ (0x00007f687796d000)
        libclsra12.so => /u01/app/ (0x00007f6877723000)
        libdbcfg12.so => /u01/app/ (0x00007f68774f6000)
        libhasgen12.so => /u01/app/ (0x00007f6876501000)
        libskgxn2.so => /u01/app/ (0x00007f68762fe000)
        libocr12.so => /u01/app/ (0x00007f6875ff3000)
        libocrb12.so => /u01/app/ (0x00007f6875d09000)
        libocrutl12.so => /u01/app/ (0x00007f6875af3000)
        libaio.so.1 => /lib64/libaio.so.1 (0x000000360d000000)
        libons.so => /u01/app/ (0x00007f68758ae000)
        libdl.so.2 => /lib64/libdl.so.2 (0x00007f68756a9000)
        libm.so.6 => /lib64/libm.so.6 (0x000000360e000000)
        libpthread.so.0 => /lib64/libpthread.so.0 (0x000000360d800000)
        libnsl.so.1 => /lib64/libnsl.so.1 (0x0000003610800000)
        libc.so.6 => /lib64/libc.so.6 (0x000000360d400000)
        /lib64/ld-linux-x86-64.so.2 (0x000000360cc00000)

Cloning Oracle software

As a consequence, you should not copy directly an Oracle Home from one machine to a new machine (even if both machines have compatible processors and operating systems) and consider that installation has been completed: you are missing the linking step, the inventory update and possibly other steps: this is not supported by Oracle Corp. You must instead clone Oracle software using the right Oracle software cloning process that will re-run the linking step among other things.

Relinking Oracle binaries in other cases

Relinking Oracle binaries is also used to enable/disabling some database options in the binaries: for example, Oracle Directed Placement Optimizations on Tru64 UNIX machines. As of Oracle 11 chopt tool is running the related linking steps.

Relinking Oracle binaries is needed after upgrading operating system as documented in the Oracle Database Administrator’s Reference 12c Release 1 (12.1) for Linux and UNIX-Based Operating Systems.

Oracle Client and Oracle Instant Client

Installing Oracle Client on UNIX is very similar to installing Oracle Database on Unix: linking step is also run. But
Oracle Instant Client installation process is very different: binaries are ready to be used (there is no linking step) and there is no Oracle inventory. However if you need to patch Oracle Instant Client you need a full Oracle Client Oracle Home
(see section Patching Instant Client Shared Libraries on Unix in Oracle Call Interface Programmer’s Guide).

Oracle XE

Oracle XE (only available on Linux for UNIX) installation process is different and very specific: you must use a RPM. This RPM has only a very small dependencies list:

$ rpm -q -R oracle-xe-11.2.0-1.0
glibc >= 2.3.4
libaio >= 0.3.104
rpmlib(PayloadFilesHavePrefix) <= 4.0-1
rpmlib(CompressedFileNames) <= 3.0.4-1

The scripts run when installing the RPM do not contain any command or script to run some linking step. To this respect Oracle XE on Linux is similar to Oracle (XE and non-XE) on Windows because installing Oracle on Windows does not have any linking step.

Post a comment or leave a trackback: Trackback URL.

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / Change )

Twitter picture

You are commenting using your Twitter account. Log Out / Change )

Facebook photo

You are commenting using your Facebook account. Log Out / Change )

Google+ photo

You are commenting using your Google+ account. Log Out / Change )

Connecting to %s

%d bloggers like this: