会员登陆  支付方式  联系我们  在线客服  网站地图       
首页 关于域浪 互联网数据中心业务、主机托管、主机租用、机架租用、带宽租用、机房介绍、机房对比、CCN网络加速 adsl专线、深圳adsl专线 虚拟主机、域名注册、数据库、企业邮局、动态域名 网络安全、网络临近平台、安全服务、防火去墙租用、安全产品、域浪抗DDOS防火墙、NetScreen防火墙 技术支持  
   当前位置:首页 >> 技术支持 >> ORACLE数据库技术 >> Oracle 9i在Red Hat7.1和7.2上的安装
 
精华文章
    一步一步教你Oracle 9...  
    ORACLE碎片整理(2)  
    ORACLE碎片整理(1)  
    关于Oracle 对 Linux ...  
    ORACLE之常用FAQ V1.0...  
    ORACLE之常用FAQ V1.0...  
    Oracle平台应用数据库...  
    Oracle的空间数据库管...  
    Oracle传统基本体系结...  
    Oracle平台下的数据分...  
    Oracle密码文件的创建...  
    Oracle数据库的安全策...  
    双机容错环境Oracle数...  
    Oracle数据库系统使用...  
    ORACLE常见错误代码分...  
    Oracle数据库管理脚本...  
    Oracle中一个日期查找...  
    在ORACLE里用存储过程...  
    Oracle数据库逻辑备份...  
    Oracle数据库系统的安...  
    Oracle数据库处理身份...  
    Oracle数据库的备份及...  
    Oracle数据库表空间恢...  
    案例讨论:Oracle两表...  
    Oracle数据库系统性能...  
    优化Oracle网络设置的...  
    Oracle9i RMAN备份及恢...  
    弥补Oracle数据库访问...  
  更多>>  
   ORACLE数据库技术
 Oracle 9i在Red Hat7.1和7.2上的安装
    本文是我在 Red Hat 7.1 (内核版本:2.4.2-2 )和 7.2(内核版本:2.4.7-10) 上安装 Oracle 9i (9.0.1) 数据库的总结,如果需要更多的信息请参考 Oracle 的文档: Oracle9i Database Documentation for Linux。 



    需要说明的是, 7.1 已经得到了 9i 和 9iAS 的验证,可以参考: " Red Hat Announces Validation Of Red Hat Linux For Oracle",但是截止到 2001年年底,7.2 的验证还是没有通过。 



下载 9i 并刻录 CD 

Oracle9i for Linux 可以从下面的站点下载: 

http://otn.oracle.com/software/products/oracle9i/htdocs/linuxsoft.htm 



Oracle 并不提供这些文件的校验和,下面是我产生的校验和: 

$ md5sum Linux9i_Disk1.cpio.gz

 Linux9i_Disk2.cpio.gz Linux9i_Disk3.cpio.gz 

f1a99eb8c8aca1d69a9eeaa8858570d7 

Linux9i_Disk1.cpio.gz 

f2444c0fa53c898e7d2f78c184829d7d 

Linux9i_Disk2.cpio.gz 

ec655402d8bc547ed031f14122da574b 

Linux9i_Disk3.cpio.gz



解开压缩文件: 

gunzip Linux9i_Disk1.cpio.gz 

Linux9i_Disk2.cpio.gz Linux9i_Disk3.cpio.gz



解开打包文件: 

cpio -idmv < Linux9i_Disk1.cpio 

cpio -idmv < Linux9i_Disk2.cpio 

cpio -idmv < Linux9i_Disk3.cpio

 

可以得到三个安装文件的目录: 

Disk1 

Disk2 

Disk3 



我用外置 USB 的 HP-8230e 刻录机,烧出这三张光盘(并非必须的步骤): 

mkisofs -r Disk1 | 

cdrecord -v --eject dev=0,0,0 speed=4 - 

mkisofs -r Disk2 | cdrecord -v --eject dev=0,0,0 speed=4 - 

mkisofs -r Disk3 | cdrecord -v --eject dev=0,0,0 speed=4 - 

(设备号可以通过执行 cdrecord -scanbus 得到)。

 

交换空间 

    Oracle 推荐的交换空间大小为物理内存的两倍或者最少 512MB,采用两者之中大的那个值。我建议使用更多的交换空间,特别是你有其他的程序运行在 Oracle 服务器上时,我的 PC 有 256MB 内存,我使用了 600MB 的交换空间。如果在安装 Oracle 时没有足够的交换空间,特别是在建库时,将会导致系统几分钟没有任何反应。 



检查交换空间: 

cat /proc/swaps

 

增加交换空间: 

dd if=/dev/zero 

of=tmpswap bs=1k count=300000 

chmod 600 tmpswap 

mkswap tmpswap 

swapon tmpswap 

"binutils" RPM 版本的问题

 

    7.1 和 7.2 随带的 binutils RPM 包使 9i 的 Universial Installer 不能跑起来,也没有更新的版本能解决这个问题,你可以有两个选择: 

下载下面版本的 RPM 包,“降级” Oracle 服务器上的 binutil : 

ftp://ftp.redhat.com/pub/redhat/

linux/7.0/en/os/i386/RedHat/RPMS/

binutils-2.10.0.18-1.i386.rpm

 

安装: 

rpm -Uvh --force --nodeps binutils-2.10.0.18-1.i386.rpm

安装完 Oracle 后,别忘了把 binutil 升级回去。 



另外一个简单的办法时在安装中等待出现下面的错误,然后手工修复: 

"Error invoking target install of makefile /

opt/oracle/product/9.0.1/

plsql/lib/ins_plsql.mk"

请参考 Running Oracle Installation 以及 Oracle Installation Errors ,我推荐使用第二种方法。 



安装 JDK 

下载 JDK 1.3.1 或者 Blackdown 1.1.8_v3(我总是使用 Blackdown ,这是 Oracle 以前推荐给 Linux 用户的)。 

根据 JDK 的文档,把 JDK 安装在 /usr/local 目录下并建立 JDK 的符号连接到 /usr/local/java: 

bzip2 -dc jdk118_v3-glibc-2.1.3.tar.bz2 | 

tar xf - -C /usr/local ln -s /usr/local/jdk118_v3 /

usr/local/java



建立 Oracle 用户 

groupadd dba 

groupadd oinstall 

useradd -g oinstall -G dba oracle 

passwd oracle



建立 Oracle 目录 

mkdir /opt/oracle 

mkdir /opt/oracle/product 

mkdir /opt/oracle/product/9.0.1 

chown -R oracle.oinstall /opt/oracle 

mkdir /var/opt/oracle 

chown oracle.dba /var/opt/oracle 

chmod 755 /var/opt/oracle

 

设置 Oracle 环境 

以 Oracle 用户进入,建立 $HOME/.bash_profile: 

# Oracle Environment 

export ORACLE_BASE=/opt/oracle 

export ORACLE_HOME=/opt/oracle/product/9.0.1 

export ORACLE_SID=test 

export ORACLE_TERM=xterm 

#export TNS_ADMIN= 设置这个变量,如果 sqlnet.ora, 

tnsnames.ora等不在$ORACLE_HOME/network/admin 目录下。 

export NLS_LANG=AMERICAN; 

export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data 

LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib:/

usr/openwin/lib 

LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/td/lib:/

usr/ucblib:/usr/local/lib 

export LD_LIBRARY_PATH 

# Set shell search paths: 

PATH=/bin:/usr/bin:/usr/sbin:/etc:/opt/bin:/

usr/ccs/bin:/usr/openwin/bin:/opt/local/GNU/bin 

PATH=$PATH:/opt/local/bin:/opt/NSCPnav/

bin:$ORACLE_HOME/bin 

PATH=$PATH:/usr/local/samba/bin:/usr/ucb: 

export PATH 

# CLASSPATH must include the following JRE locations: 

CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib 

CLASSPATH=$CLASSPATH:$ORACLE_HOME/network/jlib



启动 runInstaller 

    Oracle 不再支持字符模式的安装,因此必须设置 DISPLAY 变量,假设节点名为 oracleserver,那么 oracleserver 必须允许 runInstaller 显示 X 信息。如果你不在远程安装数据库,可以跳过下面的第一和第二步。 



第一步: 

yourdesktop:user$ 

xhost +oracleserver



第二步:从 oracleserver 的控制台上以 Oracle 用户执行: 

oracleserver:oracle$ 

export DISPLAY=yourdesktop:0.0

 

第三步a:从第一张 CD ,执行 runInstaller (不要 cd 到 /mnt/cdrom !) 

oracleserver:oracle$ mount /mnt/cdrom 

oracleserver:oracle$ /mnt/cdrom/runInstaller

 

第三步b:或者从下载点: 

oracleserver:oracle$ Disk1/

RunInstaller



运行 Oracle 安装 

下面是我回答 runInstaller 的问题: 

What would you like as 

the base directory (Inventory Location): 

/opt/oracle/oraInventory 

UNIX Group Name (permission for updating Oracle software): oinstall 

Full path name of the Oracle Home: /opt/oracle/product/9.0.1 

JDK Home Directory: /usr/local/java

 

注意: 

如果没有“降级” binutils 包的话,安装到第三张 CD 时,你会看到下面的错误: 

"Error invoking target install of makefile /opt/oracle/product/9.0.1/plsql/lib/ins_plsql.mk"

解决的办法请看后面的“Oracle 安装错误”。 



你可能还会碰到 "Oracle Net Configuration Assistant" 挂起的问题,请参考后面的”Oracle 安装中重要的技巧和提示“。 

启动 Oracle 9i 数据库 

9i 中已经没有 svrmgrl 了,所有的管理工作都听过 sqlplus 来完成: 

dba$ sqlplus /nolog 

SQL> connect / as sysdba 

SQL> startup

 

Oracle 安装中重要的技巧和提示 

如果遇到 gunzip 出错,检查文件的校验和: 

$ md5sum Linux9i_Disk1.cpio.gz 

Linux9i_Disk2.cpio.gz Linux9i_Disk3.cpio.gz 

f1a99eb8c8aca1d69a9eeaa8858570d7 Linux9i_Disk1.cpio.gz 

f2444c0fa53c898e7d2f78c184829d7d Linux9i_Disk2.cpio.gz 

ec655402d8bc547ed031f14122da574b Linux9i_Disk3.cpio.gz

不要 cd 到 /mnt/cdrom 执行 ./runInstaller ! 

否则你将不能在安装时弹出 CD,因为 unmount 不能把挂接着的 CD 卸下来。 

(译者注:我安装 9iAS 遇到的就是这样的问题啊!害得我把 CD 复制到硬盘再安装)。 



    如果忘记了设置 DISPLAY 环境变量或者忘记赋予数据库服务器在桌面 PC 上显示 X 信息的权限(例如: xhost +oracleserver),将得到下面的错误: 

Xlib: connection to ":0.0" refused by server 

Xlib: Client is not authorized to connect to Server



解决的办法是:rm -rf /tmp/OraInstall 

    如果不这样做,安装程序将挂在那里,没有任何错误信息。同时也要检查 runInstaller 是否在后台停止了运行。 



    当 runInstaller 开始配置工具时,"Oracle Net Configuration Assistant" 会挂起,简单的解决办法是停止其配置,重新配置或者继续安装,当其他安装结束后,再来一次“Retry"。 



    如果在安装中系统停止了反应,可能就是没有足够的交换空间了。如果发生这样的事情,只能等待到系统反应为止。 



    Oracle 的安装还需要运行 make 等程序,在生产环境中,你或许没有安装编译器和其他开发工具,所以,需要临时安装下面的几个包: 

cpp, egcs, egcs-c++, glibc-devel, kernel-headers 。



如果不能成功安装 9i 而需要重来的话,需要清除下面的文件和目录: 

rm -rf /etc/oraInst.loc /etc/oratab /tmp/OraInstall 

rm -rf $ORACLE_BASE/* 

/tmp/



Oracle 安装错误 

    下面是别人关于 Oracle 安装时碰到的问题和解决的办法,我并没有遇到其中的大多数问题,因此不能确定这些解答是否正确,如果你有好的解决办法或者其他问题,可以写信给我,我将会加入到这个文件中。 



首先检查/tmp/OraInstall 中的错误日志,如果遇到 make 的错误,检查: 

$ORACLE_HOME/install/make.log 。 

"Error invoking target install of makefile /opt/oracle/product/9.0.1/plsql/lib/ins_plsql.mk" 

"Error invoking target install of makefile /opt/oracle/

product/9.0.1/precomp/lib/ins-precomp.mk" 

"Error invoking target install of makefile /opt/oracle/

product/9.0.1/precomp/lib/ins-net-client" 

"Error invoking target install of makefile /opt/oracle/

product/9.0.1/precomp/lib/ins-oemagent"

 

编辑 $ORACLE_HOME/bin/genclntsh 把 LD_SELF_CONTAINED="-z defs" 

改成:LD_SELF_CONTAINED="" 

然后运行脚本: 

$ORACLE_HOME/bin/genclntsh:

$ $ORACLE_HOME/bin/genclntsh 

Created /opt/oracle/product/9.0.1/lib/libclntst9.a 

$

 

在错误对话框中点击 重试。 



"Error in setting permissions of file/directory /opt/oracle/jre/1.1.8/bin/i686/native_threads/.

extract_args.

 

    当错误框打开时,手工找到并从安装 jre 的目录下拷贝文件 .extract_args 到 runInstaller 提示文件丢失的地方。 



Oracle 的链接 

在我的主页上有一些 Oracle 的 Linux 连接。我只是涵盖和 Linux 相关的 Oracle 问题,没有涉及到具体的 Oracle 配置问题。您可以通过 电子邮件和我联系。 
  • 上一篇文章: 弥补Oracle数据库访问限制绕过的漏洞
  • 下一篇文章: 在Windows下管理Oracle9i服务
  • 域浪网络ISP经营许可证 深圳地址:深圳市罗湖区宝安北路国际商品交易大厦七楼C30室
    Tel:0755-82266883/82267566 Fax:0755-82261966
    邮编:518000 
                        Copyright © 2006-2008 elang.cn All Rights Reserved 深圳市域浪网络技术有限公司版权所有