Oracle 9i 在 Red Hat 7.1 和 7.2 上的安裝
由
徐永久 發(fā)表于 2002年01月08日 00:58。
原文出處:
http://www.puschitz.com/InstallingOracle9i.html翻譯:
FreeLAMP.com 之 WebMaster:
徐永久轉(zhuǎn)載本文請(qǐng)注明以上兩行,謝謝!
本文是我在 Red Hat 7.1 (內(nèi)核版本:2.4.2-2 )和 7.2(內(nèi)核版本:2.4.7-10) 上安裝 Oracle 9i (9.0.1) 數(shù)據(jù)庫(kù)的總結(jié),如果需要更多的信息請(qǐng)參考 Oracle 的文檔:
Oracle9i Database Documentation for Linux。
需要說(shuō)明的是, 7.1 已經(jīng)得到了 9i 和 9iAS 的驗(yàn)證,可以參考:
,但是截止到 2001年年底,7.2 的驗(yàn)證還是沒(méi)有通過(guò)。下載 9i 并刻錄 CDOracle9i for Linux 可以從下面的站點(diǎn)下載:http://otn.oracle.com/software/products/oracle9i/htdocs/linuxsoft.htmOracle 并不提供這些文件的校驗(yàn)和,下面是我產(chǎn)生的校驗(yàn)和:
$ 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
解開(kāi)壓縮文件:
gunzip Linux9i_Disk1.cpio.gz Linux9i_Disk2.cpio.gz Linux9i_Disk3.cpio.gz
解開(kāi)打包文件:
cpio -idmv < Linux9i_Disk1.cpio
cpio -idmv < Linux9i_Disk2.cpio
cpio -idmv < Linux9i_Disk3.cpio
可以得到三個(gè)安裝文件的目錄:
Disk1
Disk2
Disk3
我用外置 USB 的 HP-8230e 刻錄機(jī),燒出這三張光盤(并非必須的步驟):
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 -
(設(shè)備號(hào)可以通過(guò)執(zhí)行 cdrecord -scanbus 得到)。
交換空間
Oracle 推薦的交換空間大小為物理內(nèi)存的兩倍或者最少 512MB,采用兩者之中大的那個(gè)值。我建議使用更多的交換空間,特別是你有其他的程序運(yùn)行在 Oracle 服務(wù)器上時(shí),我的 PC 有 256MB 內(nèi)存,我使用了 600MB 的交換空間。如果在安裝 Oracle 時(shí)沒(méi)有足夠的交換空間,特別是在建庫(kù)時(shí),將會(huì)導(dǎo)致系統(tǒng)幾分鐘沒(méi)有任何反應(yīng)。
檢查交換空間:
cat /proc/swaps
增加交換空間:
dd if=/dev/zero of=tmpswap bs=1k count=300000
chmod 600 tmpswap
mkswap tmpswap
swapon tmpswap
"binutils" RPM 版本的問(wèn)題
7.1 和 7.2 隨帶的 binutils RPM 包使 9i 的 Universial Installer 不能跑起來(lái),也沒(méi)有更新的版本能解決這個(gè)問(wèn)題,你可以有兩個(gè)選擇:
下載下面版本的 RPM 包,“降級(jí)” Oracle 服務(wù)器上的 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 升級(jí)回去。
另外一個(gè)簡(jiǎn)單的辦法時(shí)在安裝中等待出現(xiàn)下面的錯(cuò)誤,然后手工修復(fù):
"Error invoking target install of makefile /opt/oracle/product/9.0.1/plsql/lib/ins_plsql.mk"
請(qǐng)參考 Running Oracle Installation 以及 Oracle Installation Errors ,我推薦使用第二種方法。
安裝 JDK
下載
JDK 1.3.1 或者
Blackdown 1.1.8_v3(我總是使用 Blackdown ,這是 Oracle 以前推薦給 Linux 用戶的)。
根據(jù) JDK 的文檔,把 JDK 安裝在 /usr/local 目錄下并建立 JDK 的符號(hào)連接到 /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
設(shè)置 Oracle 環(huán)境
以 Oracle 用戶進(jìn)入,建立 $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= 設(shè)置這個(gè)變量,如果 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
啟動(dòng) runInstaller
Oracle 不再支持字符模式的安裝,因此必須設(shè)置 DISPLAY 變量,假設(shè)節(jié)點(diǎn)名為 oracleserver,那么 oracleserver 必須允許 runInstaller 顯示 X 信息。如果你不在遠(yuǎn)程安裝數(shù)據(jù)庫(kù),可以跳過(guò)下面的第一和第二步。
第一步:yourdesktop:user$ xhost +oracleserver
第二步:從 oracleserver 的控制臺(tái)上以 Oracle 用戶執(zhí)行:
oracleserver:oracle$ export DISPLAY=yourdesktop:0.0
第三步a:從第一張 CD ,執(zhí)行 runInstaller (不要 cd 到 /mnt/cdrom !)
oracleserver:oracle$ mount /mnt/cdrom
oracleserver:oracle$ /mnt/cdrom/runInstaller
第三步b:或者從下載點(diǎn):
oracleserver:oracle$ Disk1/RunInstaller
運(yùn)行 Oracle 安裝
下面是我回答 runInstaller 的問(wèn)題: 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
注意:
如果沒(méi)有“降級(jí)” binutils 包的話,安裝到第三張 CD 時(shí),你會(huì)看到下面的錯(cuò)誤:
"Error invoking target install of makefile /opt/oracle/product/9.0.1/plsql/lib/ins_plsql.mk"
解決的辦法請(qǐng)看后面的
“Oracle 安裝錯(cuò)誤”。
你可能還會(huì)碰到 "Oracle Net Configuration Assistant" 掛起的問(wèn)題,請(qǐng)參考后面的
”Oracle 安裝中重要的技巧和提示“。
啟動(dòng) Oracle 9i 數(shù)據(jù)庫(kù)
9i 中已經(jīng)沒(méi)有 svrmgrl 了,所有的管理工作都聽(tīng)過(guò) sqlplus 來(lái)完成:
dba$ sqlplus /nolog
SQL> connect / as sysdba
SQL> startup
Oracle 安裝中重要的技巧和提示
如果遇到 gunzip 出錯(cuò),檢查文件的校驗(yàn)和:
$ 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 執(zhí)行 ./runInstaller !
否則你將不能在安裝時(shí)彈出 CD,因?yàn)?unmount 不能把掛接著的 CD 卸下來(lái)。
(譯者注:我安裝 9iAS 遇到的就是這樣的問(wèn)題啊!害得我把 CD 復(fù)制到硬盤再安裝)。
如果忘記了設(shè)置 DISPLAY 環(huán)境變量或者忘記賦予數(shù)據(jù)庫(kù)服務(wù)器在桌面 PC 上顯示 X 信息的權(quán)限(例如: xhost +oracleserver),將得到下面的錯(cuò)誤:
Xlib: connection to ":0.0" refused by server
Xlib: Client is not authorized to connect to Server
解決的辦法是:rm -rf /tmp/OraInstall
如果不這樣做,安裝程序?qū)煸谀抢?,沒(méi)有任何錯(cuò)誤信息。同時(shí)也要檢查 runInstaller 是否在后臺(tái)停止了運(yùn)行。 當(dāng) runInstaller 開(kāi)始配置工具時(shí),"Oracle Net Configuration Assistant" 會(huì)掛起,簡(jiǎn)單的解決辦法是停止其配置,重新配置或者繼續(xù)安裝,當(dāng)其他安裝結(jié)束后,再來(lái)一次“Retry"。 如果在安裝中系統(tǒng)停止了反應(yīng),可能就是沒(méi)有足夠的交換空間了。如果發(fā)生這樣的事情,只能等待到系統(tǒng)反應(yīng)為止。 Oracle 的安裝還需要運(yùn)行 make 等程序,在生產(chǎn)環(huán)境中,你或許沒(méi)有安裝編譯器和其他開(kāi)發(fā)工具,所以,需要臨時(shí)安裝下面的幾個(gè)包:
cpp, egcs, egcs-c++, glibc-devel, kernel-headers 。 如果不能成功安裝 9i 而需要重來(lái)的話,需要清除下面的文件和目錄:
rm -rf /etc/oraInst.loc /etc/oratab /tmp/OraInstall
rm -rf $ORACLE_BASE/*
/tmp/
Oracle 安裝錯(cuò)誤
下面是別人關(guān)于 Oracle 安裝時(shí)碰到的問(wèn)題和解決的辦法,我并沒(méi)有遇到其中的大多數(shù)問(wèn)題,因此不能確定這些解答是否正確,如果你有好的解決辦法或者其他問(wèn)題,可以寫信給我,我將會(huì)加入到這個(gè)文件中。
首先檢查/tmp/OraInstall 中的錯(cuò)誤日志,如果遇到 make 的錯(cuò)誤,檢查: $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=""
然后運(yùn)行腳本:$ORACLE_HOME/bin/genclntsh:
$ $ORACLE_HOME/bin/genclntsh
Created /opt/oracle/product/9.0.1/lib/libclntst9.a
$
在錯(cuò)誤對(duì)話框中點(diǎn)擊 重試。 "Error in setting permissions of file/directory /opt/oracle/jre/1.1.8/bin/i686/native_threads/.extract_args.
當(dāng)錯(cuò)誤框打開(kāi)時(shí),手工找到并從安裝 jre 的目錄下拷貝文件 .extract_args 到 runInstaller 提示文件丟失的地方。
Oracle 的鏈接
在
我的主頁(yè)上有一些 Oracle 的 Linux 連接。我只是涵蓋和 Linux 相關(guān)的 Oracle 問(wèn)題,沒(méi)有涉及到具體的 Oracle 配置問(wèn)題。您可以通過(guò)
電子郵件和我聯(lián)系。
< | >
下面的點(diǎn)評(píng)文字版權(quán)歸點(diǎn)評(píng)者所有。
(
點(diǎn)評(píng)(需審核) )
by
victor on 2002年12月12日 17:20
根據(jù)您的配置,我已經(jīng)能從win客戶端通過(guò)單獨(dú)啟動(dòng)來(lái)連接oracle服務(wù)器了但不能通過(guò)oracle manae server登錄,提示是出現(xiàn)異常錯(cuò)誤java.lang.nullpointerexception 怎么解決這個(gè)問(wèn)題?謝謝!
[
回應(yīng)此文 ]
Re: Oracle 9i 在 Red Hat 7.1 和 7.2 上的安裝
由
Pallas 發(fā)表于 2003年11月05日 15:49
我也碰到了這個(gè)問(wèn)題,怎么辦啊?哪位大俠幫幫忙啊!
[
回復(fù)本貼(需審核) ]
from:
http://www.freelamp.com/1010422680/