- 1、安装依赖包
- 2、修改内核参数
- 3、编辑/etc/security/limits.conf文件,修改操作系统对oracle用户资源的限制。在该文件中添加如下行。
- 4、在/etc/pam.d/login 文件中,使用文本编辑器或vi命令增加或修改以下内容
- 5、在/etc/profile 文件中,使用文本编辑器或vi命令增加或修改以下内容
- 6、创建安装目录(可根据情况,选择比较多空间的目录创建)
- 7、创建/etc/oraInst.loc应答文件,内容如下
- 8、设置oracle环境变量
- 9、解压oracle安装文件
- 10、复制响应文件模板
- 11、静默安装Oracle软件
- 12、增加oracle环境变量
- 13、静默配置网络
- 14、静默安装数据库
1、安装依赖包
yum install -y binutils*
yum install -y compat-libstdc*
yum install -y elfutils-libelf*
yum install -y gcc*
yum install -y glibc*
yum install -y ksh*
yum install -y libaio*
yum install -y libgcc*
yum install -y libstdc*
yum install -y make*
yum install -y sysstat*
yum install libXp* -y
yum install -y glibc-kernheaders
2、修改内核参数
#检查系统变量
sysctl -a | grep sem
sysctl -a | grep shm
sysctl -a | grep file-max
sysctl -a | grep aio-max
sysctl -a | grep ip_local_port_range
sysctl -a | grep rmem_default
sysctl -a | grep rmem_max
sysctl -a | grep wmem_default
sysctl -a | grep wmem_max
#修改内核参数
vim /etc/sysctl.conf
fs.aio-max-nr = 65536
fs.file-max = 398704
kernel.shmall = 4294967296
#物理内存的75%
kernel.shmmax = 68719476736
kernel.shmmni = 4096
kernel.sem = 250 32000 100 128
net.ipv4.ip_local_port_range = 32768 61000
net.core.rmem_default = 124928
net.core.rmem_max = 124928
net.core.wmem_default = 124928
net.core.wmem_max = 124928
#立即生效
sysctl -p
3、编辑/etc/security/limits.conf文件,修改操作系统对oracle用户资源的限制。在该文件中添加如下行。
vim /etc/security/limits.conf
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
oracle soft stack 10240
4、在/etc/pam.d/login 文件中,使用文本编辑器或vi命令增加或修改以下内容
session required /lib/security/pam_limits.so
session required pam_limits.so
5、在/etc/profile 文件中,使用文本编辑器或vi命令增加或修改以下内容
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
6、创建安装目录(可根据情况,选择比较多空间的目录创建)
groupadd -g 500 oinstall
groupadd -g 501 dba
useradd -g oinstall -G dba oracle
echo "<密码>" | passwd --stdin oracle
mkdir -p /u01/app/
chown -R oracle:oinstall /u01/app/
chmod -R 775 /u01/app/
7、创建/etc/oraInst.loc应答文件,内容如下
inventory_loc=/u01/app/oracle/oraInventory
inst_group=oinstall
#更改文件的权限
chown oracle:oinstall /etc/oraInst.loc
chmod 664 /etc/oraInst.loc
8、设置oracle环境变量
su - oracle
vi ~/.bash_profile
#在最后加上以下内容
export ORACLE_BASE=/u01/app/oracle
export ORACLE_SID=orcl
#注意,除了ORACLE_BASE和ORACLE_SID,( /etc/profile和.bash_profile中)不设置任何oracle相关环境变量(ORACLE_HOME, PATH, LD_LIBRARY_PATH等)。
#使设置生效
source /home/oracle/.bash_profile
#检查环境变量:
env|grep ORA
9、解压oracle安装文件
unzip linux.x64_11gR2_database_1of2.zip
unzip linux.x64_11gR2_database_2of2.zip
10、复制响应文件模板
mkdir etc
cp /home/oracle/database/response/* /home/oracle/etc/
#设置响应文件权限
su - root
chmod 700 /home/oracle/etc/*.rsp
11、静默安装Oracle软件
su - oracle
#修改安装Oracle软件的响应文件/home/oracle/etc/db_install.rsp
sed -i s/oracle.install.option=/oracle.install.option=INSTALL_DB_SWONLY/g db_install.rsp
sed -i s/ORACLE_HOSTNAME=/ORACLE_HOSTNAME=java-linux-test/g db_install.rsp
sed -i s/UNIX_GROUP_NAME=/UNIX_GROUP_NAME=oinstall/g db_install.rsp
sed -i s#INVENTORY_LOCATION=#INVENTORY_LOCATION=/u01/app/oracle/oraInventory#g db_install.rsp
sed -i s/SELECTED_LANGUAGES=/SELECTED_LANGUAGES=en,zh_CN,zh_TW/g db_install.rsp
sed -i s#ORACLE_HOME=#ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1#g db_install.rsp
sed -i s#ORACLE_BASE=#ORACLE_BASE=/u01/app/oracle#g db_install.rsp
sed -i s/oracle.install.db.InstallEdition=/oracle.install.db.InstallEdition=EE/g db_install.rsp
sed -i s/oracle.install.db.isCustomInstall=false/oracle.install.db.isCustomInstall=true/g db_install.rsp
sed -i s/oracle.install.db.DBA_GROUP=/oracle.install.db.DBA_GROUP=dba/g db_install.rsp
sed -i s/oracle.install.db.OPER_GROUP=/oracle.install.db.OPER_GROUP=oinstall/g db_install.rsp
sed -i s/oracle.install.db.config.starterdb.type=/oracle.install.db.config.starterdb.type=GENERAL_PURPOSE/g db_install.rsp
sed -i s/oracle.install.db.config.starterdb.globalDBName=/oracle.install.db.config.starterdb.globalDBName=orcl/g db_install.rsp
sed -i s/oracle.install.db.config.starterdb.SID=/oracle.install.db.config.starterdb.SID=orcl/g db_install.rsp
sed -i s/oracle.install.db.config.starterdb.memoryLimit=/oracle.install.db.config.starterdb.memoryLimit=512/g db_install.rsp
sed -i s/oracle.install.db.config.starterdb.password.ALL=/oracle.install.db.config.starterdb.password.ALL=oracle/g db_install.rsp
sed -i s/DECLINE_SECURITY_UPDATES=/DECLINE_SECURITY_UPDATES=true/g db_install.rsp
各参数含义:
oracle.install.option=INSTALL_DB_SWONLY //29 行 安装类型
ORACLE_HOSTNAME=java-linux-test //37 行 主机名称
UNIX_GROUP_NAME=oinstall //42 行 安装组
INVENTORY_LOCATION=/u01/app/oracle/oraInventory //47 行 INVENTORY目录
SELECTED_LANGUAGES=en,zh_CN,zh_TW //78 行 选择语言
ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1 //83 行 oracle_home
ORACLE_BASE=/u01/app/oracle //88 行 oracle_base
oracle.install.db.InstallEdition=EE //99 行 oracle版本
oracle.install.db.isCustomInstall=true //108行 自定义安装
oracle.install.db.DBA_GROUP=dba //142行 dba用户组
oracle.install.db.OPER_GROUP=oinstall //147行 oper用户组
oracle.install.db.config.starterdb.type=GENERAL_PURPOSE //160行 数据库类型
oracle.install.db.config.starterdb.globalDBName=orcl //165行 globalDBName
oracle.install.db.config.starterdb.SID=orcl //170行 SID
oracle.install.db.config.starterdb.memoryLimit=512 //192行 自动管理内存的最小内存(M)
oracle.install.db.config.starterdb.password.ALL=oracle //233行 设定所有数据库用户使用同一个密码
DECLINE_SECURITY_UPDATES=true //385行 设置安全更新
cd database
./runInstaller -silent -force -responseFile /home/oracle/etc/db_install.rsp
#安装中,如果提示[WARNING]不必理会,此时安装程序仍在进行,如果出现[FATAL],则安装程序已经停止了。
查看安装日志信息了解安装进度
cd $ORACLE_BASE/oraInventory/logs
tail -f installActions*.log
#出现类似如下提示表示安装完成:
...
/u01/app/oracle/product/11.2.0/db_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.
-------------------------------------------------------------------
12、增加oracle环境变量
su - oracle
vi ~/.bash_profile
#在最后加上以下内容
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
13、静默配置网络
$ORACLE_HOME/bin/netca /silent /responseFile /home/oracle/etc/netca.rsp
14、静默安装数据库
#修改仅安装数据库的响应文件 /home/oracle/etc/dbca.rsp
sed -i 's#GDBNAME = "orcl11g.us.oracle.com"#GDBNAME="orcl.oracle"#g' dbca.rsp
sed -i 's#SID = "orcl11g"#SID="orcl"#g' dbca.rsp
sed -i 's/#CHARACTERSET = "US7ASCII"/CHARACTERSET = "ZHS16GBK"/g' dbca.rsp
sed -i 's/#MEMORYPERCENTAGE = "40"/MEMORYPERCENTAGE = "60"/g' dbca.rsp
sed -i 's/#EMCONFIGURATION = "NONE"/EMCONFIGURATION = "LOCAL"/g' dbca.rsp
#修改如下:
GDBNAME="orcl.oracle"
SID="orcl"
CHARACTERSET = "ZHS16GBK"
MEMORYPERCENTAGE = "60"
EMCONFIGURATION = "LOCAL"
SYSPASSWORD = "oracle"
SYSTEMPASSWORD = "oracle"
DBSNMPPASSWORD = "oracle"
SYSMANPASSWORD = "oracle"
$ORACLE_HOME/bin/dbca -silent -responseFile /home/oracle/etc/dbca.rsp
#建库后实例检查
ps -ef | grep ora_ | grep -v grep | wc -l
ps -ef | grep ora_ | grep -v grep
#建库后监听检查
lsnrctl status