RedHat4 64位操作系统下,安装Oracle 10g
 
一、引言
最近,在Redhat4.8 x86_64上安装了Oracle 10g,在安装过程中遇到了一些问题,尤其令人头疼的 gcc 32位编译器的问题。
现将此期间遇到的问题和解决方法总结一下,与大家分享。
 
二、环境准备及安装
1、安装环境、Oracle版本
    OS:     Redhat4u8 x86_64
    OracleOracle 10201 for linux_x86_64(安装介质可以从Oracle官方网站获得,www.oracle.com
    
2、开始安装,环境准备
    安装Oracle前的准备工作包括:
Ø 用户、用户组
Ø 用户环境变量设置
Ø 安装Oracle所需的软件包
    其中,安装软件包时需特别注意,软件包不仅要安装64位,也要同时安装32位的。
下面是具体的准备过程
l 所需软件包的检查与安装
RedHat4.8X86_64)上安装Oracle 10G,需要安装如下软件包
binutils-2.15.92.0.2-25 (x86_64)
compat-db-4.1.25-9 (i386)
compat-db-4.1.25-9 (x86_64)
compat-libstdc++-296-2.96-132.7.2 (i386)
control-center-2.8.0-12.rhel4.5 (x86_64)
gcc-3.4.6-11 (x86_64)
gcc-c++-3.4.6-11 (x86_64)
glibc-2.3.4-2.43 (i686)
glibc-2.3.4-2.43 (x86_64)
glibc-common-2.3.4-2.43 (x86_64)
gnome-libs-1.4.1.2.90-44.1 (x86_64)
libstdc++-3.4.6-11 (i386)
libstdc++-3.4.6-11 (x86_64)
libstdc++-devel-3.4.6-11 (x86_64)
make-3.80-7.EL4 (x86_64)
pdksh-5.2.14-30.6 (x86_64)
sysstat-5.0.5-25.el4 (x86_64)
xscreensaver-4.18-5.rhel4.14 (x86_64)
setarch-1.6-1 (x86_64)
glibc-2.3.4-2.43 (i686)
glibc-2.3.4-2.43 (x86_64)
glibc-devel-2.3.4-2.43 (x86_64)
glibc-devel-2.3.4-2.43 (i386)
libaio-0.3.105-2 (i386)
libaio-0.3.105-2 (x86_64)
libaio-devel-0.3.105-2 (i386)
libaio-devel-0.3.105-2 (x86_64)
compat-gcc-32-3.2.3-47.3 (x86_64)
compat-gcc-32-c++-3.2.3-47.3 (x86_64)
xorg-x11-deprecated-libs-devel-6.8.2-1.EL.63 (x86_64)
xorg-x11-deprecated-libs-devel-6.8.2-1.EL.63 (i386)
xorg-x11-devel-6.8.2-1.EL.63 (x86_64)
xorg-x11-devel-6.8.2-1.EL.63 (i386)
fontconfig-devel-2.2.3-13.el4 (x86_64)
freetype-devel-2.1.9-8.el4.6 (x86_64)
 
可以运行如下命令检查,注意x86_64i368的版本都要有。
rpm -q --qf '%{NAME}-%{VERSION}-%{RELEASE} (%{ARCH})\n' \binutils compat-db compat-libstdc++-296 \
    control-center gcc gcc-c++ glibc glibc-common gnome-libs libstdc++ libstdc++-devel make pdksh \
    sysstat xscreensaver setarch \
    glibc glibc-devel libaio libaio-devel \
    compat-gcc-32 compat-gcc-32-c++- \
    xorg-x11-deprecated-libs-devel xorg-x11-devel \
    fontconfig-devel freetype-devel
还有一个包 compat-oracle-rhel4-1.0-5.i386.rpm,这个包不在RedHat的安装介质中,需单独下载安装,如果不安装,会在OUI的“configuration assistant”处失败。
下载地址:
http://oss.oracle.com/projects/compat-oracle/dist/files/RedHat/compat-oracle-rhel4-1.0-5.i386.rpm
 
l  用户、用户组以及用户环境变量
  Ø 用户、用户组
# groupadd –g 602 dba
# groupadd –g 601 oinstall
# useradd -g oinstall -G dba -m –u 601 oracle
# mkdir –p /opt/apps/oracle
# chown oracle:oinstall /opt/apps/oracle
 
  Ø 环境变量,
编辑oracle用户.bash_profile文件,增加如下内容
trap " " 0 1 2 3 5 9 15
trap clear 0
export TMP=/tmp
export TMPDIR=$TMP
export ORACLE_BASE=/opt/apps/oracle
export ORACLE_HOME=$ORACLE_BASE/product/10.2.0/db_1
export ORACLE_SID=orasid
export ORACLE_TERM=xterm
export PATH=/usr/sbin:$PATH
export PATH=$ORACLE_HOME/bin:$PATH
# export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib:/usr/lib:/usr/local/lib
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib64:/usr/lib64:/usr/local/lib64:/usr/X11R6/lib64/
export CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib
export LD_ASSUME_KERNEL=2.6.9
export NLS_LANG="Simplified Chinese_china".ZHS16GBK
#
LC_CTYPE=zh_CN.GB2312
LC_ALL=zh_CN
LANG=zh_CN.GB2312
umask 022
#
if [ $USER = "oracle" ]; then
if [ $SHELL = "/bin/ksh" ]; then
ulimit -p 16384
ulimit -n 65536
else
ulimit -u 16384 -n 65536
fi
fi
 
vi /etc/sysctl.conf    行末添加以下内容
# add content for oracle install
kernel.shmall = 2097152
kernel.shmmax = 2147483648
kernel.shmmni = 4096
# semaphores: semmsl, semmns, semopm, semmni
kernel.sem = 250 32000 100 128
fs.file-max = 65536
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
执行下述命令。导入刚才写入的参数。
# sysctl p
 
vi /etc/security/limits.conf 行末添加以下内容
# add content for oracle install
* soft nproc 2047
* hard nproc 16384
* soft nofile 1024
* hard nofile 65536
 
vi /etc/pam.d/login  行末添加以下内容
# add content for oracle install
session required pam_limits.so
 
vi /etc/selinux/config 确保以下内容
SELINUX=disabled
 
解压Oracle安装介质
# gzip -dc 10201_database_linux_x86_64.cpio.gz | cpio -div
 
3、安装
在运行Oracle安装文件前,需设置C编译环境,CC=/usr/bin/gcc32,使用32位编译器,否则编译会出错,安装后sqlplus无法正常运行,也就更谈不上以后的建库了。
# su – oracle
$ export CC=/usr/bin/gcc32
$ ../runInstaller
进入图形安装界面,安装过程中没有特殊,在此不作描述。
 
三、结语
以上是安装过程中需要注意的地方,请各位参考、指正。