下載 9i:
http://otn.oracle.com/software/products/oracle9i/htdocs/linuxsoft.htm
$ 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
刻盤:
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 得到
交換空間: 物理內存的兩倍或者至少512MB
cat /proc/swaps
增加交換空間:
dd if=/dev/zero of=tmpswap bs=1k count=300000
chmod 600 tmpswap
mkswap tmpswap
swapon tmpswap
共享內存配置: 寫入/etc/rc.d/rc.local或者/etc/rc.d/rc5.d/S78oradb:
echo 65536 > /proc/sys/fs/file-max #set max descriptors
echo 131072 > /proc/sys/kernel/shmmax #half of the physical memory
echo 4096 > /proc/sys/kernel/shmmni
echo 2097152 > /proc/sys/kernel/shmall
echo 100 32000 100 100 > /proc/sys/kernel/sem #semmsl semmns semopm semmni
echo 1024 65000 > /proc/sys/net/ipv4/ip_local_port_range
環境配置:寫入oracle用戶的.cshrc
ulimit -u 16384 #maximun processes
ulimit -n 66536 #maximum descriptors
"binutils" RPM 版本的問題
7.1 和 7.2 隨帶的 binutils RPM 包不兼容9i 的 Universial Installer,有兩個解決方案:
a. “降級” 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 升級回去。
b. 在安裝中等待出現下面的錯誤,然后手工修復:
"Error invoking target install of makefile /opt/oracle/product/9.0.1/plsql/lib/ins_plsql.mk"
請參考 Running Oracle Installation 以及 Oracle Installation Errors ,我推薦使用第二種方法。
安裝 JDK
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 用戶
mkdir /home/oracle
groupadd -g 1001 dba
useradd -g 1001 -u 1001 -d /home/oracle oracle
passwd oracle
chown -R oracle:dba /home/oracle
注: 記得為oracle用戶指定tcsh
建立相關目錄
mkdir /home/tmp
chmod 777 /home/tmp
mkdir /home/oracle_app
chown -R oracle:dba /home/oracle_app
mkdir /home/oradata
mkdir /home/oradata/FREEDB
mkdir /home/oradata/FREEDB/admin
mkdir /home/oradata/FREEDB/admin/bdump
mkdir /home/oradata/FREEDB/admin/cdump
mkdir /home/oradata/FREEDB/admin/udump
mkdir /home/oradata/FREEDB/archive
mkdir /home/oradata/FREEDB/config
mkdir /home/oradata/FREEDB/control
mkdir /home/oradata/FREEDB/data
mkdir /home/oradata/FREEDB/redo
chown -R oracle:dba /home/oradata
ln -s /home/oradata /oradata
mkdir /var/opt/oracle
chown oracle:dba /var/opt/oracle
chmod 755 /var/opt/oracle
設置 Oracle 環境
以 Oracle 用戶進入,建立 $HOME/.bashrc或者.cshrc
export ORACLE_BASE=/home/oracle_app
export ORACLE_HOME=/home/oracle_app
export ORACLE_SID=XFDB
export ORACLE_TERM=xterm
#export TNS_ADMIN= 設置這個變量,如果 sqlnet.ora, tnsnames.ora等不在$ORACLE_HOME/network/admin 目錄下。
export NLS_LANG=american_america.ZHS16GBK;
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=$CLASSPATH:$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib
CLASSPATH=$CLASSPATH:$ORACLE_HOME/network/jlib
For RedHat 9.0:
export JAVA_HOME=/usr/local/java_1.4.1_or_above #否則runinstaller會掛死
export LD_ASSUME_KERNEL=2.4.1 #make sure to use java GUI tools such as netca, etc. when using Oracle.
啟動 runInstaller
Oracle 不再支持字符模式的安裝,因此必須設置 DISPLAY 變量。
a> yourdesktop:user$ xhost +oracleserver
b> 從 oracleserver 的控制臺上以 Oracle 用戶執行:
oracleserver:oracle$ export DISPLAY=yourdesktop:0.0
c> 從第一張 CD 或者從下載點(Disk1/RunInstaller)執行 runInstaller
oracleserver:oracle$ mount /mnt/cdrom
oracleserver:oracle$ /mnt/cdrom/runInstaller
注:不要 cd 到 /mnt/cdrom 去執行runInstaller,因為 unmount 不能把掛接著的 CD 卸下來
安裝確認信息:
The base directory (Inventory Location): /home/oracle_app/oraInventory
UNIX Group Name (permission for updating Oracle software): dba
Full path name of the Oracle Home: /home/oracle_app
JDK Home Directory: /usr/local/java
忘記設置 DISPLAY 環境變量或者忘記在桌面 PC 上運行 xhost +oracleserver,將得到下面的錯誤:
Xlib: connection to ":0.0" refused by server
Xlib: Client is not authorized to connect to Server
對7.1,7.2,如果沒有“降級” binutils 包,安裝到第三張 CD 時會發生如下錯誤:
"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
retry
ins_ctx.mk錯誤的解決方法:
edit $ORACLE_HOME/ctx/lib/env_ctx.mk.
add $(LDLIBFLAG)dl into the line INSO_LINK=-L$(CTXLIB) $(LDLIBFLAG)m right at the position.
retry.
Error in setting permissions of file/directory /home/oracle_app/jre/1.1.8/bin/i686/native_threads/.extract_args.
手工找到并從安裝 jre 的目錄下拷貝文件 .extract_args 到 runInstaller 提示文件丟失的地方。
For RedHat 9.0:
You will get make errors for oemadmin and a few others. Simply ignore.
其他注意事項:
當 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/*
啟動 Oracle 9i 數據庫
9i 中已經沒有 svrmgrl 了,所有的管理工作都通過 sqlplus 來完成:
dba$ sqlplus /nolog
SQL> connect / as sysdba
SQL> startup
補丁:
http://otn.oracle.com/support/patches.htm: 察看最新的patch set.
metalink.oracle.com: 下載patch, 需要csi注冊賬號,文件名為p<patch-id>_<oracle_ver>_<platform>.zip