本文借鑒了http://www.puschitz.com/的文章:
Installing Oracle 9i on RedHat Linux 7.1, 7.2, 7.3, 8.0, 9, Red Hat Advanced Server 2.1, and on Red Hat Enterprise Linux Advanced Server 3 (RHEL AS 3)
機器配置:hp lh6000
cpu pIII 700
內存 512M
兩塊 36G硬盤,做raid0
Linux版本:RedHat Linux.7.1
分區: /boot :100M swap :1024M / :所有剩余空間
選擇安裝xwindow、kde。
設置xwindow可以支持如xmanager這樣的工具遠程登陸linux。設置如下:
#vi /etc/X11/xdm/xdm-config
在最後一行: DisplayManager.requestPort: 0 前面加!號注釋掉此行。
#vi /etc/X11/xdm/Xservers
在最後一行::0 local /usr/X11R6/bin/X 前面加#號注釋掉這一行。
#vi /etc/X11/xdm/Xaccess
找到#* #any host can get a login window
把這一行前面的#號去掉,變成:
* #any host can get a login window
最後運行#xdm。這樣使用xmanager等工具就可以連接Linux了!!!
如果想要每次啟動自動啟動xdm,那麼請在/etc/rc.d/rc.local文件尾部加入/etc/X11R6/bin/xdm
安裝oracle9i
Oracle9i for Linux 可以從下面的站點下載:
http://otn.oracle.com/software/products/oracle9i/htdocs/linuxsoft.htm
一共有三個軟件包:
Linux9i_Disk1.cpio.gz
Linux9i_Disk2.cpio.gz
Linux9i_Disk3.cpio.gz
解包
如果要一步解開這些包使用如下命令:
zcat Linux9i_Disk1.cpio.gz | cpio -idmv
zcat Linux9i_Disk2.cpio.gz | cpio -idmv
zcat Linux9i_Disk3.cpio.gz | cpio –idmv
如果兩步解開這些包:
第一步:解壓
#gunzip -d Linux9i_Disk1.cpio.gz
#gunzip -d Linux9i_Disk2.cpio.gz
#gunzip -d Linux9i_Disk3.cpio.gz
第二步:解包:
cpio -idmv < Linux9i_withjre_Disk1.cpio
cpio -idmv < Linux9i_nojre_Disk2.cpio
cpio -idmv < Linux9i_Disk3.cpio
進行完上面的操作後,會得到Disk1, Disk2 ,Disk3 三個文件夾。這三個文件夾是oracle9i的安裝文件
交換空間
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
安裝: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"
修復方法:
編輯 $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
然後選擇重試。
安裝 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
以下是我的$HOME/.bash_profile文件的內容
# .bash_profile# Get the aliases and functionsif [ -f ~/.bashrc ]; then . ~/.bashrcfi# User specific environment and startup programsPATH=$PATH:$HOME/binBASH_ENV=$HOME/.bashrcexport BASH_ENV PATHunset USERNAMEexport ORACLE_BASE=/opt/oracle export ORACLE_HOME=/opt/oracle/product/9.0.1 export ORACLE_SID=test export ORACLE_TERM=xterm 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 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=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib CLASSPATH=$CLASSPATH:$ORACLE_HOME/network/jlib export CLASSPATH
啟動 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
(注意:使用我的這種安裝方式,不用設置DISPLAY變量)
運行 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
'www.mypchelp.cn
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 卸下來。
如果忘記了設置 DISPLAY 環境變量或者忘記賦予數據庫服務器在桌面 PC