- 安裝前准備
-
- 下載oracle版本
- 地址:http://docs.oracle.com/cd/E21901_01/index.html ,下載2個文件分別是 linux.x64_11gR2_database_1of2.zip,linux.x64_11gR2_database_2of2.zip
-
安裝前須知:
- 內存(RAM)的最小要求是 1GB,建議 2GB 及以上。
- 虛擬內存 swap 建議:內存為 1GB~2GB 時建議swap大小為內存大小的 1.5 倍;內存為 2GB~16GB 時建議swap大小為內存的大小;內存超過 16GB 時swap保持16GB。
- 要求臨時文件目錄,如 /tmp 的磁盤空間至少 1GB。
- 磁盤空間要求:企業版為4.35GB的安裝空間和1.7GB以上的數據文件空間;標准版為4.22GB的安裝空間和1.5GB以上的數據文件空間。
- 需要 X window 圖形界面。
- 需要 root 用戶權限
-
本文安裝環境:
- 操作系統 CentOS 6.4 2.6.32-358.el6.x86_64(desktop),2GB RAM,80GB 硬盤空間(4GB swap、100MB /boot、40GB /)
- 主機名 mophee, IP 192.168.80.19(靜態)
- 環境:VMware Workstation 9.0
- 必要安裝包的安裝
- centos root下執行以下腳本
-
yum install -y binutils compat-libstdc++-33 elfutils-libelf elfutils-libelf-devel gcc gcc-c++ glibc glibc-common glibc-devel libaio libaio-devel libgcc libstdc++ libstdc++-devel make numactl sysstat libXp unixODBC unixODBC-devel
- 下載oracle版本
-
-
- 或以下(推薦)
-
#提前安裝好需要的rpm包 yum install gcc libaio libaio-devel libstdc++ libstdc++-devel libgcc elfutils-libelf-devel glibc-devel glibc-devel gcc-c++ compat-libstdc++-33 unixODBC unixODBC-devel
有一個rpm包需要獨立下載pdksh-5.2.14-37.el5_8.1.x86_64,然后rpm -ivh安裝即可。
創建oinstall組
groupadd oinstall創建dba組
groupadd dba創建oracle用戶
useradd -g oinstall -G dba oracle修改oracle用戶的密碼
passwd oraclevi /etc/sysctl.conf #在文件末尾添加以下內容 fs.aio-max-nr = 1048576 fs.file-max = 6815744 kernel.shmall = 2097152 kernel.shmmax = 536870912 kernel.shmmni = 4096 kernel.sem = 250 32000 100 128 net.ipv4.ip_local_port_range = 9000 65500 net.core.rmem_default = 262144 net.core.rmem_max = 4194304 net.core.wmem_default = 262144 net.core.wmem_max = 1048586 #刷新參數 sysctl -p vi /etc/security/limits.conf #在文件末尾添加以下內容 oracle soft nproc 2047 oracle hard nproc 16384 oracle soft nofile 1024 oracle hard nofile 65536 oracle soft stack 10240 #創建安裝Oracle軟件所需要的目錄 mkdir -p /u01/oracle_11g_r2 chown -R oracle:oinstall /u01/oracle_11g_r2 chmod -R 775 /u01/oracle_11g_r2 #日志目錄 mkdir /u01/oralnventory chown -R oracle:oinstall /u01/oralnventory/ chmod -R 775 /u01/oralnventory/ vi /home/oracle/.bash_profile #在文件末尾添加以下內容 umask 022 export ORACLE_BASE=/u01/oracle_11g_r2 export ORACLE_HOME=$ORACLE_BASE/oracle/product/11.2.0/db_1 export ORACLE_SID=orcl export PATH=$PATH:HOME/bin:$ORACLE_HOME/bin vi /etc/pam.d/login #在文件末尾添加以下內容 session required /lib/security/pam_limits.so session required pam_limits.so vi /etc/profile #在文件末尾添加以下內容 if [ $USER = "oracle" ]; then if [ $SHELL = "/bin/ksh" ]; then ulimit -p 16384 ulimit -n 65536 else ulimit -u 16384 -n 65536 fi fi #刷新參數 source /etc/profile
-
- 安裝
關閉SELinux(在root帳號下操作):
編輯SELinux配置文件 vi /etc/selinux/config,將SELINUX的值設為 disabled,如下:
1
|
SELINUX=disabled;
|
修改該文件可使重啟系統后不啟動SELinux。關閉當前已開啟的SELinux使用如下命令:
1
|
setenforce 0
|
修改/etc/hosts文件(在root帳號下操作):
編輯文件 vi /etc/hosts,添加一行:
1
|
192.168.80.19 mophee
|
若不進行此操作會在安裝時彈出警告,並且可能影響監聽程序的正常運行,所以建議做這個修改。
創建所需的目錄(在root帳號下操作):
把oracle安裝在 /opt/oracle 目錄下,所以需創建該目錄:
1
2
3
|
mkdir
/opt/oracle
;
chown
oracle:oinstall
/opt/oracle
;
chmod
755
/opt/oracle
;
|
安裝時還需要設置 Inventory 目錄,所以需創建該目錄:
1
2
3
|
mkdir
/opt/oraInventory
;
chown
oracle:oinstall
/opt/oraInventory
;
chmod
755
/opt/oraInventory
;
|
安裝包相關:
Oracle 11g R2的安裝包被壓縮成兩個文件:linux.x64_11gR2_database_1of2.zip、linux.x64_11gR2_database_2of2.zip,將它們上傳到安裝機器上,並使用 unzip linux.x64_11gR2_database_1of2.zip; unzip linux.x64_11gR2_database_2of2.zip; 進行解壓縮,將得到一個名稱為 database 的目錄。我把它放在 /home/oracle/database 中。
由於安裝過程是以 oracle 身份進行的,所以需確保oracle帳號對 /home/oracle/database 有執行權限,可使用如下命令將該目錄賦予oracle帳號所有,並擁有執行權限:
1
2
|
chmod
-R 700
/home/oracle/database
;
chown
-R oracle:oinstall
/home/oracle/database
;
|
————————退出 root,以 oracle 身份登錄———————————-
設置oracle帳號登錄時環境(以oracle身份登錄):
編輯文件 vi /home/oracle/.bash_profile,添加如下行:
1
2
3
4
5
6
|
ORACLE_BASE=
/opt/oracle
;
#安裝目錄
ORACLE_HOME=$ORACLE_BASE
/11g
;
#oracle家目錄
ORACLE_SID=orcl;
#實例名
LD_LIBRARY_PATH=$ORACLE_HOME
/lib
;
PATH=$PATH:$ORACLE_HOME
/bin
:$HOME
/bin
;
export
ORACLE_BASE ORACLE_HOME ORACLE_SID LD_LIBRARY_PATH PATH;
|
保存退出后執行如下命令使以上設置立即生效:
1
|
source
/home/oracle/
.bash_profile
|
開始安裝(以oracle身份登錄):
1
2
|
export
LANG=en_US;
##
/home/oracle/database/runInstaller
;
##執行該程序開始安裝
|
- 安裝收尾
最后的完善工作
vi /etc/oratab
orcl:/u01/oracle_11g_r2/oracle/product/11.2.0/db_1:Y(把N改成Y)
分別編輯以下兩個文件
vi /u01/oracle_11g_r2/oracle/product/11.2.0/db_1/bin/dbstart
vi /u01/oracle_11g_r2/oracle/product/11.2.0/db_1/bin/dbshut
找到 ORACLE_HOME_LISTNER=$1
改成 ORACLE_HOME_LISTNER=$ORACLE_HOME
啟動腳本如下
- #!/bin/bash
- # chkconfig: 2345 90 10
- export ORACLE_BASE=/u01/oracle_11g_r2
- export ORACLE_HOME=$ORACLE_BASE/oracle/product/11.2.0/db_1
- export ORACLE_SID=orcl
- export PATH=$PATH:$ORACLE_HOME/bin
- ORCL_OWN="oracle"
- # if the executables do not exist -- display error
- if [ ! -f $ORACLE_HOME/bin/dbstart -o ! -d $ORACLE_HOME ]
- then
- echo "Oracle startup: cannot start"
- exit 1
- fi
- # depending on parameter -- start, stop, restart
- # of the instance and listener or usage display
- case "$1" in
- start)
- # Oracle listener and instance startup
- echo -n "Starting Oracle: "
- su - $ORCL_OWN -c "$ORACLE_HOME/bin/dbstart"
- touch /var/lock/subsys/oradb
- su - $ORCL_OWN -c "$ORACLE_HOME/bin/emctl start dbconsole"
- echo "OK"
- ;;
- stop)
- # Oracle listener and instance shutdown
- echo -n "Shutdown Oracle: "
- su - $ORCL_OWN -c "$ORACLE_HOME/bin/emctl stop dbconsole"
- su - $ORCL_OWN -c "$ORACLE_HOME/bin/dbshut"
- rm -f /var/lock/subsys/oradb
- echo "OK"
- ;;
- reload|restart)
- $0 stop
- $1 start
- ;;
- *)
- echo "Usage: 'basename $0' start|stop|restart|reload"
- exit 1
- esac
- exit 0
復制以上腳本內容,在/etc/init.d目錄下創建一個名為oracle的文件,然后黏貼進去,保存退出,然后chmod +x 給它執行權限,別忘了chkconfig添加開機啟動以及防火牆規則的添加,到此數據庫就安裝完成了。