centos静默式安装Oracle11g
1. Centos及Oracle版本
Centos:CentOS release 6.4 (Final)
Oracle:linux.x64_Oracle_11gR2_database
2. 硬件环境要求
2.1 内存要求
- 物理内存要求:
至少1G,查看物理内存命令:
# grep MemTotal /proc/meminfo
- 虚拟内存要求:
物理内存4-8G,要求虚拟内存为2倍物理内存;
物理内存8-32G,要求虚拟内存为1.5倍物理内存;
物理内存32G,要求虚拟内存为32G;
查看虚拟内存命令:
# grep SwapTotal /proc/meminfo
增加虚拟内存示例:
# dd if=/dev/zero of=/swapadd bs=1024 count=2006424
# mkswap /swapadd
# swapon /swapadd
2.2 存储空间要求
/tmp目录下需至少1G空间
# df -h /tmp
如果不足1G需设置oracle用户的TMP和TMPDIR环境变量。
对数据库安装目录,需至少4.35G空间,对数据文件目录,需至少1.68G空间。
3. 软件环境要求
3.1 内核版本要求
需满足:2.6.18 or later
检查命令:
# uname -r
3.2 系统包要求
以下系统包或以上版本(32个)必须满足:
binutils-2.17.50.0.6
compat-libstdc++-33-3.2.3
compat-libstdc++-33-3.2.3 (32 bit)
elfutils-libelf-0.125
elfutils-libelf-devel-0.125
gcc-4.1.2
gcc-c++-4.1.2
glibc-2.5-24
glibc-2.5-24 (32 bit)
glibc-common-2.5
glibc-devel-2.5
glibc-devel-2.5 (32 bit)
glibc-headers-2.5
ksh-20060214
libaio-0.3.106
libaio-0.3.106 (32 bit)
libaio-devel-0.3.106
libaio-devel-0.3.106 (32 bit)
libgcc-4.1.2
libgcc-4.1.2 (32 bit)
libstdc++-4.1.2
libstdc++-4.1.2 (32 bit)
libstdc++-devel 4.1.2
make-3.81
numactl-devel-0.9.8.x86_64
sysstat-7.0.2
unixODBC-2.2.11
unixODBC-2.2.11 (32 bit)
unixODBC-devel-2.2.11
elfutils-libelf-devel-static-0.125
kernel-headers-2.6.18
libgomp-4.1.2
检查命令:
# rpm -q package_name
4. 创建用户组及用户
# /usr/sbin/groupadd oinstall
# /usr/sbin/groupadd dba
# /usr/sbin/useradd -g oinstall -G dba oracle
# passwd oracle
5. 配置内核参数
5.1 检查内核参数
下表为需要检查的内核参数、最小值、检查命令、及参数文件路径:
参数 |
最小值 |
检查命令 |
文件路径 |
semmsl |
250 |
# /sbin/sysctl -a | grep sem |
/proc/sys/kernel/sem |
semmns |
32000 |
||
semopm |
100 |
||
semmni |
128 |
||
shmall |
2097152 |
# /sbin/sysctl -a | grep shm |
/proc/sys/kernel/shmall |
shmmax |
4GB-1byte或物理内存的一半,两者最小值. Default: 536870912 |
/proc/sys/kernel/shmmax |
|
shmmni |
4096 |
/proc/sys/kernel/shmmni |
|
file-max |
6815744 |
# /sbin/sysctl -a | grep file-max |
/proc/sys/fs/file-max |
ip_local_port_range |
Minimum: 9000 Maximum: 65500 |
# /sbin/sysctl -a | grep ip_local_port_range |
/proc/sys/net/ipv4/ip_local_port_range |
rmem_default |
262144 |
# /sbin/sysctl -a | grep rmem_default |
/proc/sys/net/core/rmem_default |
rmem_max |
4194304 |
# /sbin/sysctl -a | grep rmem_max |
/proc/sys/net/core/rmem_max |
wmem_default |
262144 |
# /sbin/sysctl -a | grep wmem_default |
/proc/sys/net/core/wmem_default |
wmem_max |
1048576 |
# /sbin/sysctl -a | grep wmem_max |
/proc/sys/net/core/wmem_max |
aio-max-nr |
Maximum: 1048576 |
# cat /proc/sys/fs/aio-max-nr |
/proc/sys/fs/aio-max-nr |
对于需要修改的参数,要在/etc/sysctl.conf(如果没有该文件则创建)中修改。如果该文件中存在参数配置,直接修改,否则增加新行。
以下是对SCB UPRR生产环境的分析:
Oracle推荐设置 /etc/sysctl.conf是否需修改,如何修改
kernel.sem = 250 32000 100 128 ##修改,增加本行
kernel.shmall = 2097152 ##满足,无需增加或修改
kernel.shmmax = 536870912 ##满足,无需增加或修改
kernel.shmmni = 4096 ##满足,无需增加或修改
fs.file-max = 6815744 ##修改,增加本行
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 ##修改,增加本行
fs.aio-max-nr = 1048576 ##修改,增加本行
5.2 修改内核参数
经上述分析,SCB UPRR生产环境在/etc/sysctl.conf中无参数修改,但有参数增加,增加内容如下:
# vi /etc/sysctl.conf
kernel.sem = 250 32000 100 128
fs.file-max = 6815744
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
fs.aio-max-nr = 1048576
修改后,使设置生效:
# /sbin/sysctl -p
执行生效命令后,再次检查确认参数设置:
# /sbin/sysctl -a
6 用户限制设置
6.1用户文件限制检查
切换到安装用户oracle
# su - oracle
检查以下参数是否在推荐的范围内
Type |
Item |
Recommended Ranges |
Command |
soft |
nofile |
at least 1024 |
$ ulimit -Sn |
hard |
nofile |
at least 65536 |
$ ulimit -Hn |
soft |
nproc |
at least 2047 |
$ ulimit -Su |
hard |
nproc |
at least 16384 |
$ ulimit -Hu |
soft |
stack |
at least 10240 KB |
$ ulimit -Ss |
hard |
stack |
at least 10240 KB at most 32768 KB |
$ ulimit -Hs |
6.2修改用户限制
$ su - root
在文件/etc/security/limits.conf中加入以下内容:
# vi /etc/security/limits.conf
oracle soft nofile 1024
oracle hard nofile 65536
oracle soft nproc 2047
oracle hard nproc 16384
在/etc/pam.d/login中增加以下内容:
vi /etc/pam.d/login
session required /lib/security/pam_limits.so
session required pam_limits.so
在/etc/profile中加入以下内容:
# 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
7 关闭SELinux
# vi /etc/sysconfig/selinux
#SELINUX=enforcing
SELINUX=disabled
8 创建安装目录
# mkdir -p /u01/app/
# chown -R oracle:oinstall /u01/app/
# chmod -R 775 /u01/app/
9 设置环境变量
# su - oracle
$ vi ~/.bash_profile
umask 022
export ORACLE_BASE=/u01/app/oracle
export ORACLE_SID=uprr
$ source /home/oracle/.bash_profile
$ unset ORACLE_HOME
$ unset TNS_ADMIN
注意,除了ORACLE_BASE和ORACLE_SID,( /etc/profile和.bash_profile中)不设置任何oracle相关环境变量(ORACLE_HOME, PATH, LD_LIBRARY_PATH等)。
检查环境变量:
$ env | more
检查用户文件权限掩码:
$ umask
10 静默安装软件
10.1 创建oraInst.loc
$ su - root
# vi /etc/oraInst.loc
inventory_loc=/u01/app/oracle/oraInventory
inst_group=oinstall
# chown oracle:oinstall /etc/oraInst.loc
# chmod 664 /etc/oraInst.loc
10.2 创建响应文件
# su - oracle
mkdir etc
cp linux.x64_Oracle_11gR2_database/database/response/* etc/
vi db_install.rsp
仅安装Oracle软件的响应文件UPRR_INSTALL_DB_SWONLY.rsp
oracle.install.responseFileVersion=/oracle/install/rspfmt_dbinstall_response_schema_v11_2_0
oracle.install.option=INSTALL_DB_SWONLY
ORACLE_HOSTNAME=build001
UNIX_GROUP_NAME=oinstall
INVENTORY_LOCATION=/u01/app/oracle/oraInventory
SELECTED_LANGUAGES=en,zh_CN,zh_TW
ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1
ORACLE_BASE=/u01/app/oracle
oracle.install.db.InstallEdition=EE
oracle.install.db.isCustomInstall=false
oracle.install.db.DBA_GROUP=dba
oracle.install.db.OPER_GROUP=dba
DECLINE_SECURITY_UPDATES=true
创建数据库的响应文件UPRR_DBCA.rsp
[GENERAL]
RESPONSEFILE_VERSION = "11.2.0"
OPERATION_TYPE = "createDatabase"
[CREATEDATABASE]
GDBNAME = "uprr"
SID = "uprr"
TEMPLATENAME = "General_Purpose.dbc"
DATAFILEDESTINATION = "/u01/app/oracle/oradata"
RECOVERYAREADESTINATION= "/u01/app/oracle/flash_recovery_area"
CHARACTERSET = "AL32UTF8"
NATIONALCHARACTERSET= "UTF8"
NET配置的响应文件使用Oracle默认即可,无需修改,该文件在Oracle安装包的路径:
$cp database/response/netca.rsp /home/oracle/UPRR_NETCA.rsp
$ su - root
# chmod 700 /home/oracle/UPRR_INSTALL_DB_SWONLY.rsp
10.3 安装Oracle
安装:
# su - oracle
$ cd database
$ ./runInstaller -silent -debug -force -responseFile /home/oracle/UPRR_INSTALL_DB_SWONLY.rsp
备注:(可选参数-noconfig -IgnoreSysPreReqs)
出现类似如下提示表示安装完成:
#-------------------------------------------------------------------
...
/u01/app/oracle/oraInventory/orainstRoot.sh
/u01/app/oracle/product/11.2.0/dbhome_1/root.sh
To execute the configuration scripts:
1. Open a terminal window
2. Log in as "root"
3. Run the scripts
4. Return to this window and hit "Enter" key to continue
Successfully Setup Software.
设置环境变量
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1
export TNS_ADMIN=$ORACLE_HOME/network/admin
export PATH=.:${PATH}:$HOME/bin:$ORACLE_HOME/bin
export PATH=${PATH}:/usr/bin:/bin:/usr/bin/X11:/usr/local/bin
export LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:$ORACLE_HOME/lib
export LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:$ORACLE_HOME/oracm/lib
export LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:/lib:/usr/lib:/usr/local/lib
export CLASSPATH=${CLASSPATH}:$ORACLE_HOME/JRE
export CLASSPATH=${CLASSPATH}:$ORACLE_HOME/JRE/lib
export CLASSPATH=${CLASSPATH}:$ORACLE_HOME/jlib
export CLASSPATH=${CLASSPATH}:$ORACLE_HOME/rdbms/jlib
export CLASSPATH=${CLASSPATH}:$ORACLE_HOME/network/jlib
export LIBPATH=${CLASSPATH}:$ORACLE_HOME/lib:$ORACLE_HOME/ctx/lib
export ORACLE_OWNER=oracle
export SPFILE_PATH=$ORACLE_HOME/dbs
export ORA_NLS10=$ORACLE_HOME/nls/data
source /home/oracle/.bash_profile
11 静默配置网络
$ $ORACLE_HOME/bin/netca /silent /responseFile /home/oracle/UPRR_NETCA.rsp
/u01/app/oracle/product/11.2.0/dbhome_6/srvm/admin/getcrshome 没有可执行权限?
12 静默安装数据库
# su - oracle
$ $ORACLE_HOME/bin/dbca -silent -responseFile /home/oracle/UPRR_DBCA.rsp
安装期间查看日志信息了解进度:
$ tail -100f $ORACLE_BASE/cfgtoollogs/dbca/$ORACLE_SID/$ORACLE_SID.log
建库后实例检查
$ ps -ef | grep ora_ | grep -v grep | wc -l
$ ps -ef | grep ora_ | grep -v grep
建库后监听检查
$ lsnrctl status
如果使用归档日志
$ sqlplus / as sysdba
SQL> shutdown immediate;
SQL> startup mount;
SQL> alter database archivelog;
SQL> alter database flashback on; (如果要启用数据库闪回功能则执行)
SQL> alter database open;
SQL> execute utl_recomp.recomp_serial(); (重新编译所有可能失效对象)
SQL> alter system archive log current; (手工归档测试)
默认安装的数据库用户检查
SQL> set lines 256 pages 500
SQL> select USER_ID,USERNAME,ACCOUNT_STATUS,DEFAULT_TABLESPACE from dba_users order by 1;