Tuesday, 6 December 2011

Oracle Database 10g R2 installation on RHEL5 x86

Overview:
This article is a comprehensive guide for the installation of Oracle Database 10g Release 2 (10.2.0.1.0) 32-bit on Redhat Enterprise Linux 5 (RHEL5) 32-bit Operating System Environment.
The official documentation for installation of Oracle Database 10g R2 32bit on Linux can be downloaded from the below mentioned link:
http://docs.oracle.com/cd/B19306_01/install.102/b15660/toc.htm 




Objective of the Article:
By the time we finish this article, we should be able to understand the following:
(1)Installation of oracle database (10.2.0.1.0) x86 on Redhat Enterprise Linux 5 (RHEL5) x86.
(3)Creation & configuration of general-purpose Oracle 10g (10.2.0.1.0) database that makes use of the local file system for physical database file storage (control files, data files, flash recovery area, online redo log files).




Installation of Redhat Enterprise Linux-5 x86:
Install Redhat Enterprise Linux 5 x86 on your machine.
For More information about RHEL5 installation visit the below site::




Download Oracle Database Software:
We first have to download the required Oracle Database software packages from the Oracle Technology Network (OTN) or Oracle Edelivery Site and then extract the Oracle Database Software packages.
Download the Oracle Database 10g Release 2 (10.2.0.1.0) Software for Linux x86 Operating System Environment.
Link for downloading oracle Database Software Package::
http://www.oracle.com/technetwork/database/enterprise-edition/downloads/index.html




Hardware Requirements Check:
Note:Login to the system as a root user for performing the below activities.
Memory Requirements:
Minimum:1 GB of RAM
To determine the RAM size, enter the following command:
[root@redhat1 ~]# grep MemTotal /proc/meminfo
Note:If the size of the RAM is less than the required size, then you must install more memory before continuing.
Available RAM SWAP Space Requirement
Between 1 GB and 2 GB 1.5 times the size of the RAM
Between 2 GB and 8 GB Equal to the size of the RAM
More than 8 GB 0.75 times the size of RAM
To determine the size of the configured swap space, enter the following command:
[root@redhat1 ~]# grep SwapTotal /proc/meminfo
Note:If there is a need of increasing swap space, see O/S documentation for increasing the swap space.


Disk Space Requirements:
At least 400 MB of free disk space should be available in the /tmp directory.
To determine the amount of disk space available in the /tmp directory, enter the following command:
[root@redhat1 ~]# df -h /tmp
If there is less than 400 MB of free disk space available in the /tmp directory, then do one of the below mentioned steps:
Ξ Delete unnecessary files from the tmp directory.
Ξ Increase the size of tmp directory as follows (Extend the file system that contains the /tmp directory):
[root@redhat1 ~]# vim /etc/fstab
Go to the row containig tmpfs and replace "defaults" with "rw,size=1200m". (or the size you want).


N.B:After doing this we have to reboot the machine so that resized tmp value takes effect.
The above discussed method is for RHEL, for increasing tmpfs of other flavour of Linux O/S please visit the vendor's website.
Disk space requirements for software files, and data files for each installation type on Linux x86:
Installation Type Minimum Requirement for Software Files (GB)
Enterprise Edition 1.5
Standard Edition 1.5
Installation Type Minimum Requirement for Data Files (GB)
Enterprise Edition 1.7
Standard Edition 1.5
To determine the amount of free disk space on the system, enter the following command:
[root@redhat1 ~]# df -h
If your diskspace is not enough, please contact administrator for increasing the disk space.




 For all the screenshots , please visit the link::: http://www.sensehaze.com 



Package Requirements Check:
After the installation of RHEL5 x86, the next task is to install all packages required by Oracle Database 10g R2 x86. During the installation process the Oracle Universal Installer performs prerequisites checks before the actual installation of database. For ensuring that these prerequisite checks complete successfully, ensure that all the packages listed below are installed properly.The following are the list of packages required for Oracle Database 10g Release 2 (10.2) x86 on RHEL-5 x86:
  • binutils-2.17.50.0.6
  • compat-db-4.2.52
  • compat-libstdc++-33-3.2.3
  • compat-gcc-34-3.4.6
  • compat-gcc-34-c++-3.4.6
  • gcc-4.1.2
  • gcc-c++-4.1.2
  • glibc-2.5-24
  • glibc-common-2.5
  • glibc-devel-2.5
  • glibc-headers-2.5
  • libstdc++-4.1.2
  • libstdc++-devel-4.1.2
  • libaio-0.3.106
  • libaio-devel-0.3.106
  • libXp-1.0.0-
  • make-3.81
  • openmotif-2.3.0
  • setarch-2.0
  • sysstat-7.0.2
The packages listed above can be found on the installer disc/image of Redhat Enterprise Linux 5 x86 or can be downloaded from the vendor's website.
To determine whether the required packages are installed, enter commands similar to the following:
[root@redhat1 ~]# rpm -q package_name
e.g:  [root@redhat1 ~]# rpm –q compat-db-4.2.52-5.1.i386.rpm 


if the package is not installed then install the package as mentioned below:
[root@redhat1 ~]# rpm -ivh package_name 


N.B: To use ODBC, you must also install the additional ODBC RPMs.
The odbc packages can be downloaded from http://www.unixodbc.org




 Creation of Required O/S Users and Groups:

The following local operating system user and groups are required for oracle database installation:
  • Oracle Inventory Group -- oinstall
  • OSBDA Group -- dba
  • Oracle Software Owner User -- Oracle
Check whether the groups/user exists , if doesn't exist please create them. Follow the below mentioned steps...
  1. To determine whether "oinstall" group exists, type the following command:
    [root@redhat1 ~]# more /etc/oraInst.loc
    If the output shows oinstall group then the group exists and need not to be created.
    .
  2. To determine whether "dba" group exists, type the following command:
    [root@redhat1 ~]#grep dba /etc/group
    If the output shows dba group then the group exists and need not to be created.
    .
  3. To determine whether "oracle" user exists, type the following command:
    [root@redhat1 ~]#id oracle
    If the output shows oracle user then the user exists and need not to be created.
    The output should be similar to following, indicating "oinstall" as primary and "dba" as secondary group.
    uid=500(oracle) gid=500(oinstall) groups=501(dba).
    If the primary group is not "oinstall" and the user "oracle" is not the member of "dba" group then we have to modify the user "oracle" as mentioned below::
    [root@redhat1 ~]#usermod -g oinstall -G dba oracle
    .
  4. If the user or the required groups doesn't exist then create them as mentioned below:
    [root@redhat1 ~]# groupadd -g 501 oinstall
    [root@redhat1 ~]# groupadd -g 502 dba
    [root@redhat1 ~]# useradd -m -u 501 -g oinstall -G dba oracle
    Now check the status of "oracle" user.
    [root@redhat1 ~]# id oracle
    The output should be similar to following, indicating "oinstall" as primary and "dba" as secondary group.
    uid=500(oracle) gid=500(oinstall) groups=501(dba).
    Now set the password of "oracle" user.
    [root@redhat1 ~]# passwd oracle
    and input a password for "oracle" user.
  5. Verify that the User nobody Exists:
    Before installtion of oracle software, complete the following steps to verify that the user "nobody" exists on the system:
    To determine if the user exists, enter the following command:
    [root@redhat1 ~]# id nobody
    If this command displays information about the "nobody" user, then you do not have to create that user.
    If the user "nobody" does not exist, then enter the following command to create it:
    [root@redhat1 ~]# useradd nobody



Configuration of Kernel Parameters:
Verify that the kernel parameters shown in the following table are set to values greater than or equal to the minimum value shown.
Using any text editor, edit the /etc/sysctl.conf file, and add or edit lines similar to the following:
 fs.file-max  65536
 kernel.shmall  2097152
 kernel.shmmax  2147483648
 kernel.shmmni  4096
 kernel.sem  250 32000 100 128
 net.ipv4.ip_local_port_range  1024 65000
 net.core.rmem_default  262144
 net.core.rmem_max  262144
 net.core.wmem_default  262144
 net.core.wmem_max  262144


After adding the above lines to the /etc/sysctl.conf file, they persist each time the system reboots. If you would like to make these kernel parameter value changes to the current system without having to reboot, enter the following command:
[root@redhat1 ~]# sysctl -p


 For all the screenshots , please visit the link::: http://www.sensehaze.com 


If the output of the above command shows any error, please rectify the error before proceeding to next step.

To improve the performance on Linux systems, Oracle recommends us to increase the shell limits for the oracle software owner user "oracle".
Update the resource limits in the /etc/security/limits.conf configuration file for the installation owner (Here "oracle" user is the owner).
----------------------------
oracle  soft  nproc  2047
oracle  hard  nproc  16384
oracle  soft  nofile  1024
oracle  hard  nofile  65536
----------------------------
[root@redhat1 ~]# vim /etc/security/limits.conf


Edit the /etc/pam.d/login file and add following lines:
session required /lib/security/pam_limits.so
session required pam_limits.so


"Disable secure linux" and "Firewall" also.


Creation of Required Directories:
The next step is to create directory that will be used to store the "Oracle Database software", "Oracle Database Datafiles" and "Flash Recovery Data".
After the directory is created, we must then specify the correct owner, group, and permissions for it.
For example:
[root@redhat1 ~]# mkdir -p /u01/app/oracle
[root@redhat1 ~]# chown -R oracle:oinstall /u01/app/oracle
[root@redhat1 ~]# chmod -R 775 /u01/app/oracle


 Mount Oracle Database Disc:
If the installer is in zip format then unzip it .If it is on a disc then mount the disc and copy the contents as follows:
N.B: I have created "oracle_soft" named directory for storing "oracle database installation files".
[root@redhat1 ~]# mkdir -p /oracle_soft
[root@redhat1 ~]# chown -R oracle:oinstall /oracle_soft/
[root@redhat1 ~]# chmod -R 775 /oracle_soft/

 Copy the installation files to the above created directory.




Configuring the oracle User’s Environment:
Set the default file mode creation mask (umask) to 022 for "oracle" user. For setting so, do the following:
[root@redhat1 ~]# su - oracle
[oracle@redhat1 ~]$ vim ~/.bash_profile
Add a line as written below and save the file.
umask 022
N.B:Before starting the Oracle Universal Installer, we should first verify that the server from where we are doing the installation, have X server installed on it. For verification we can type "xclok" in the terminal, it will show a clock if X server is available.
Before starting the installation we have to run the xhost + command as root from the console to allow X Server connections.

 [root@redhat1 ~]# xhost +


If we are performing installation from a remote machine then we have to give complete IP address of the remote machine, as shown below:
[oracle@redhat1 ~]$ export DISPLAY=IP_REMOTE_MACHINE:0.0 


Installation of Oracle Database:
For RHEL 5:Modify "database/install/oraparam.ini" file and add "redhat-5" to "Certified Versions" section.


After the above activity, start Oracle Universal Installer (OUI) and install Oracle Database as follows:
[root@redhat1 ~]# su - oracle
Go to the directory where our installation software is copied and type "./runInstaller" , then your installation will begin:
[oracle@redhat1 ~]$cd /oracle_soft/
[oracle@redhat1 ~]$ ./runInstaller

For all the screenshots , please visit the link::: http://www.sensehaze.com  



Set Oracle User Profile:
Open the profile file and add the below mentioned lines:

export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=/u01/app/oracle/product/10.2.0/db_1
export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin
[oracle@redhat1 ~]$ vim ~/.bash_profile
Or use any editor of your choice, to edit the profile of "Oracle" user.


After editing the profile run it for checking errors.
[oracle@redhat1 ~]$ . ~/.bash_profile
If there is any syntax error in the profile it will be reported.If there is no error then we will get the prompt silently.
This completes setting up of Oracle User Environment.




Listener Creation:
Open command prompt(terminal) & type “netca”




Database Creation:
Open command prompt and type "dbca"




Connect to the Database:
Open command prompt(terminal).
[oracle@redhat1 ~]$ export ORACLE_SID=mydb
[oracle@redhat1 ~]$ sqlplus / as sysdba
And you will be connected to the database.


For all the screenshots , please visit the link::: http://www.sensehaze.com





















No comments:

Post a Comment