在redhat 9 上安装oracle 9.2.0.4 时,DBCA 出错的解决办法

发表于:2007-07-02来源:作者:点击数: 标签:
如何在各种版本的 linux 上安装oracle 的资料已经很多了,也介绍的很详细,按说只要按照 步骤一步步来,应该不会出现问题。我也曾经在redhat 9 上安装过 oracle 9.2.0.1, 没有出现 任何问题。但最近我在redhat 9 上安装 oracle 9.2.0.4( 这个版本是OTN上可以

如何在各种版本的linux 上安装oracle 的资料已经很多了,也介绍的很详细,按说只要按照
步骤一步步来,应该不会出现问题。我也曾经在redhat 9 上安装过 oracle 9.2.0.1, 没有出现
任何问题。但最近我在redhat 9 上安装 oracle 9.2.0.4( 这个版本是OTN上可以下载的,9.2.0.1
的下载链接已经没有了)时,在最后使用DBCA创建数据库时,出现了以下的错误:
     

click finish, 弹出确认画面,click ok, 这时,本应该进入DBCA创建数据库的画面,DBCA却异常退出,commandline 显示的文字为:
   /u01/oracle/product/9.2.0.4/bin/dbca: line 124:  2542 Killed                 
$JRE_DIR/bin/jre -DORACLE_HOME=$OH -DJDBC_PROTOCOL=thin -mx64m -classpath $CLASSPA
TH oracle.sysman.assistants.dbca.Dbca $ARGUMENTS
(蓝色的部分是DBCA的进行号,不同的机器上不相同)
 我尝试了很多次,都会出现这个错误。可我曾经在redhat 9 上安装过9.2.0.1, 没有任何
问题,看来应该是9.2.0.4 的问题了。我在google 上搜索到一篇在fedora core 1 上
安装 9.2.0.4 的文章(http://www.oracle-base.com/articles/9i/Oracle9iInstallationOnFedora1.php)
,其中有这样一段:
Before a database instance can be created some of the Oracle tools must be forced to look at an alternative JRE:

mv $ORACLE_HOME/JRE $ORACLE_HOME/JRE_ORIGln -s /usr/java/jdk1.3.1_09/jre $ORACLE_HOME/JREsu - rootln -s /usr/java/jdk1.3.1_09/jre/bin/java /usr/java/jdk1.3.1_09/jre/bin/jreln -s /usr/java/jdk1.3.1_09/jre/bin/i386/native_threads/java /usr/java/jdk1.3.1_09/jre/bin/i386/native_threads/jreexit
With this done the DBCA can be started using dbca from the command line.
其中的 jdk1.3.1_09 是作者要求从sun 网站下载的。
   如此看来应该是JRE 的版本不对了。oracle 一般使用的JRE 是 1.1.8(实在不明白为什么)
   到 $ORACLE_BASE/jre 目录下,发现oracle 自己已经有1.3.1版的JRE
   ls $ORACLE_BASE/jre
    1.1.8/    1.3.1/
   只要使用1.3.1 的JRE就可以了。通过察看dbac 的script , 我的修改方法如下:
   1. rm $ORACLE_HOME/JRE (此JRE目录是1.1.8 的符号链接)
   2. ln -s $ORACLE_BASE/jre/1.3.1 $ORACLE_HOME/JRE
   3. cd $ORACLE_BASE/jre/1.3.1/bin
   4. ln -s $ORACLE_BASE/jre/1.3.1/bin/.java_wrapper jre
      (或者: ln -s java jre)
   5. cd i386/native_threads
   6. ln -s java jre
   
   这时,从commandline 启动dbca, 就可以解决上面的问题。
  
   感想:
       其实oracle 自己就可以做好这些事情,为什么要用户去完成这些枯燥的事情呢? 

原文转自:http://www.ltesting.net