我爱编程

CentOS7 安装Oracle 11g R2

2017-07-19  本文已影响0人  Minty_

一、安装环境

CentOS Linux 7
Oracle 11g R2

二、安装前准备

2.1. 修改主机名称

#查看主机名称
[root@oracle ~]# hostnamectl status
[root@oracle ~]# hostnamectl set-hostname oracle

2.2. 修改hosts文件
修改hosts文件是为了保持ip 与 主机名对应

[root@oracle ~]# vim /etc/hosts
#新增ip与主机名对应
127.0.0.1 oracle
10.10.0.7 oracle #本机ip地址
#重启机器
[root@oracle ~]# reboot

2.3. 关闭Selinux(太深奥,先关闭了)

[root@oracle ~]# sed -i "s/SELINUX=enforcing/SELINUX=disabled/" /etc/selinux/config  
[root@oracle ~]# setenforce 0

2.4. 防火墙开放 1521 端口

#centos7防火墙与centos6防火墙有比较大差异
#关闭centos7防火墙
[root@oracle ~]# systemctl stop firewalld.service
#关闭开机启动
[root@oracle ~]# systemctl disable firewalld.service

#安装iptables防火墙
[root@oracle ~]# yum install iptables-services
[root@oracle ~]# vim /etc/sysconfig/iptables
#新增1521接口
-A INPUT -m state --state NEW -m tcp -p tcp --dport 1521 -j ACCEPT
#设置开机启动
[root@oracle ~]# systemctl enable iptables
#重启iptabls服务
[root@oracle ~]# systemctl restart iptables.service

2.5 安装所需的软件包
查看Oracle安装文档中列出的Package Requirements可以查看在不同平台上需要的软件包。

binutils-2.23.52.0.1-12.el7.x86_64 
compat-libcap1-1.10-3.el7.x86_64 
gcc-4.8.2-3.el7.x86_64 
gcc-c++-4.8.2-3.el7.x86_64 
glibc-2.17-36.el7.i686 
glibc-2.17-36.el7.x86_64 
glibc-devel-2.17-36.el7.i686 
glibc-devel-2.17-36.el7.x86_64 
ksh
libaio-0.3.109-9.el7.i686 
libaio-0.3.109-9.el7.x86_64 
libaio-devel-0.3.109-9.el7.i686 
libaio-devel-0.3.109-9.el7.x86_64 
libgcc-4.8.2-3.el7.i686 
libgcc-4.8.2-3.el7.x86_64 
libstdc++-4.8.2-3.el7.i686 
libstdc++-4.8.2-3.el7.x86_64 
libstdc++-devel-4.8.2-3.el7.i686 
libstdc++-devel-4.8.2-3.el7.x86_64 
libXi-1.7.2-1.el7.i686 
libXi-1.7.2-1.el7.x86_64 
libXtst-1.2.2-1.el7.i686 
libXtst-1.2.2-1.el7.x86_64 
make-3.82-19.el7.x86_64 
sysstat-10.1.5-1.el7.x86_64

Oracle ODBC Drivers
On Oracle Linux 6, Red Hat Enterprise Linux 6, and Asianux Server 4:

unixODBC-2.3.1-6.el7.x86_64 or later
unixODBC-2.3.1-6.el7.i686 or later
unixODBC-devel-2.3.1-6.el7.x86_64 or later
unixODBC-devel-2.3.1-6.el7.i686 or later

安装软件包

yum -y install binutils compat-libstdc++-33 compat-libstdc++-33.i686 elfutils-libelf elfutils-libelf-devel gcc gcc-c++ glibc glibc.i686 glibc-common glibc-devel glibc-devel.i686 glibc-headers ksh libaio libaio.i686 libaio-devel libaio-devel.i686 libgcc libgcc.i686 libstdc++ libstdc++.i686 libstdc++-devel make sysstat unixODBC unixODBC

2.6. 创建用户组与用户

[root@oracle ~]# groupadd oinstall
[root@oracle ~]# groupadd dba 
#可不需要该用户组 oper
[root@oracle ~]# groupadd oper 
[root@oracle ~]# useradd -g oinstall -G dba,oper oracle
[root@oracle ~]# passwd oracle

2.7. 修改kernel内核

[root@oracle ~]# vim /etc/sysctl.conf 
#配置文件内加入 修改以下参数。如果没有可以自己添加,如果默认值比参考值大,则不需要修改。
kernel.shmmni = 4096 #这个内核参数用于设置系统范围内共享内存段的最大数量。该参数的默认值是 4096 。通常不需要更改。
kernel.shmmax = 2147483648  #该参数定义了共享内存段的最大尺寸(以字节为单位)。缺省为32M,对于oracle来说,该缺省值太低了,通常将其设置为2G。
kernel.shmall = 2097152 #该参数表示系统一次可以使用的共享内存总量(以页为单位)。缺省值就是2097152,通常不需要修改。
kernel.sem = 250 32000 100 128
fs.aio-max-nr = 1048576
fs.file-max = 65536 #设置最大打开文件数
net.ipv4.ip_local_port_range = 9000 65500  #可使用的IPv4端口范围
net.core.rmem_default = 262144
net.core.rmem_max = 4194304
net.core.wmem_default = 262144
net.core.wmem_max = 1048586

保存后退出并立即生效:

[root@oracle ~]# sysctl -p

2.8. 修改系统资源限制

[root@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

#修改用户验证选项 关联设置
[root@oracle ~]# vim /etc/pam.d/login
#加入以下语句: 
session required  /lib64/security/pam_limits.so
session required   pam_limits.so
#(注意:根据最后一条session规则的注释,应该加在最后一条规则之前)

2.9. 创建安装目录与目录权限

#创建安装目录,并赋予用户与用户组
#oracle目录 安装目录
#oradata 数据存储目录
#inventory 清单目录
#fast_recovery_area 恢复目录
[root@oracle ~]# mkdir -p /data/oracle/product/11.2.0

[root@oracle ~]# mkdir /data/oracle/oradata

[root@oracle ~]# mkdir /data/oracle/inventory

[root@oracle ~]# mkdir /data/oracle/fast_recovery_area

[root@oracle ~]# chown -R oracle:oinstall /data/oracle

[root@oracle ~]# chmod -R 775 /data/oracle

2.10. 创建Oracle环境变量

#11G R1需要,R2可省略
[root@oracle ~]# vim /etc/profile
#在末尾增加以下内容
if [ $USER = "oracle" ]; then      
    if [ $SHELL = "/bin/sh" ]; then          
        ulimit -p 16384           
        ulimit -n 65536      
    else           
         ulimit -u 16384 -n 65536      
    fi
fi

三、安装Oracle Database

3.1. 上传安装文件到home目录,并解压

[oracle@oracle ~]# unzip linux.x64_11gR2_database_1of2.zip
[oracle@oracle ~]# unzip linux.x64_11gR2_database_2of2.zip

3.2. 准备oracle安装应答模板文件db_install.rsp文件

[oracle@oracle database]$ cp response/* /usr/local/oracle/
[oracle@oracle oracle]$ chmod 755 ./*.rsp
#编辑
[oracle@oracle oracle]$ vim db_install.rsp 
#修改文件中一下内容
//安装类型,只装数据库软件
oracle.install.option=INSTALL_DB_SWONLY             
//主机名称(命令hostname查询)
ORACLE_HOSTNAME=oracle                             
// 安装组
UNIX_GROUP_NAME=oinstall                       
//INVENTORY目录(**不填就是默认值,本例此处需修改,因个人创建安装目录而定)
INVENTORY_LOCATION=/usr/local/oraInventory         
// 选择语言 
SELECTED_LANGUAGES=en,zh_CN                       
// oracle_home *路径根据目录情况注意修改 本例安装路径/usr/local/oracle
ORACLE_HOME=/usr/local/oracle/product/11.2.0/db_1      
// oracle_base *注意修改
ORACLE_BASE=/usr/local/oracle                          
// oracle版本 
oracle.install.db.InstallEdition=EE                  
//自定义安装,否,使用默认组件
oracle.install.db.isCustomInstall=false              
//dba用户组
oracle.install.db.DBA_GROUP=dba                      
//oper用户组
oracle.install.db.OPER_GROUP=dba                     
// **注意此参数 设定一定要为true
DECLINE_SECURITY_UPDATES=true  

3.3. 设置Oracle用户环境变量

[oracle@oracle ~]$ vim .bash_profile 
#添加以下内容
export ORACLE_BASE=/data/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0
export ORACLE_SID=infoyb
export ORACLE_OWNER=oracle
export NLS_LANG=american_america.AL32UTF8
export LANG=en_US.UTF-8

PATH=$PATH:$HOME/.local/bin:$HOME/bin:$ORACLE_HOME/lib:$ORACLE_HOME/bin

export PATH

#立即生效
[oracle@oracle ~]$ source .bash_profile 

3.4. 在oracle 用户下安装

#进入解压目录
[oracle@oracle ~]$ cd ~/database
[oracle@oracle ~]$  ./runInstaller -silent -ignorePrereq -responseFile /usr/local/oracle/db_install.rsp

/home/database是安装包解压后的路径,此处根据安装包解压所在位置做修改,因人而异。
  runInstaller 是主要安装脚本
  -silent 静默模式
  -force 强制安装
  -ignorePrereq忽略warning直接安装。
  -responseFile读取安装应答文件。

出现以下内容代表安装成功

根据提示内容,切换root用户执行以下语句。

/data/oracle/inventory/orainstRoot.sh
/data/oracle/product/11.2.0/root.sh

四、以静默方式配置监听

[oracle@oracle ~]$ netca /silent /responseFile /home/oracle/response/netca.rsp

成功运行后,在/data/oracle/product/11.2.0/network/admin/中生成listener.ora和sqlnet.ora

通过netstat命令可以查看1521端口正在监听。

五、以静默方式建立新库,同时也建立一个对应的实例

[oracle@oracle ~]$ vim /home/oracle/response/dbca.rsp

GDBNAME= "infoyb"

SID =" infoyb"

SYSPASSWORD= "com.oracle2015"

SYSTEMPASSWORD= "com.oracle2015"

SYSMANPASSWORD= "com.oracle2015"

DBSNMPPASSWORD= "com.oracle2015"

DATAFILEDESTINATION=/data/oracle/oradata

RECOVERYAREADESTINATION=/data/oracle/fast_recovery_area

CHARACTERSET= "AL32UTF8"

TOTALMEMORY= "6553"

其中TOTALMEMORY ="6553" 为6553MB,物理内存8G*80%。

进行静默配置:

[oracle@oracle ~]$  dbca -silent -responseFile /home/oracle/response/dbca.rsp

查看监听状态:

登陆查看实例状态:

[oracle@oracle ~]$ sqlplus / as sysdba
#select status from v$instance;

六、创建表空间与用户

6.1.创建表空间

create tablespace infoyb logging datafile'/data/oracle/oradata/infoyb/infoyb.dbf' size 1024m autoextend on next 100m maxsize 10240m extent management local;

6.2.创建用户

create user infoyb identified by infoyb default tablespace infoyb;

6.3.给用户赋权限

#为了省事,先把DBA权限赋值。
grant dba to infoyb;

七、链接测试

八、设置开机启动

8.1.修改/data/oracle/product/11.2.0/bin/dbstart

[oracle@oracle ~]$ vim /data/oracle/product/11.2.0/bin/dbstart
#将ORACLE_HOME_LISTNER=$1
#修改为ORACLE_HOME_LISTNER=$ORACLE_HOME

8.2.修改/data/oracle/product/11.2.0/bin/dbshut

[oracle@oracle ~]$ vim /data/oracle/product/11.2.0/bin/dbshut
#将ORACLE_HOME_LISTNER=$1
#修改为ORACLE_HOME_LISTNER=$ORACLE_HOME

8.3.修改/etc/oratab文件

[oracle@oracle ~]$ vim /etc/oratab
#将infoyb:/data/oracle/product/11.2.0:N中最后的N改为Y

8.4.创建启动文件

#用root用户执行
[root@oracle ~]$ vim /etc/init.d/oracle  


#新增以下内容



#!/bin/sh  
# chkconfig: 345 61 61  
# description: Oracle 11g R2 AutoRun Servimces  
# /etc/init.d/oracle  
#  
# Run-level Startup script for the Oracle Instance, Listener, and  
# Web Interface  
export ORACLE_BASE=/data/oracle  
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0
export ORACLE_SID=infoyb
export ORACLE_UNQNAME=$ORACLE_SID    
export PATH=$ORACLE_HOME/bin:/user/sbin:$PATH  
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$LD_LIBRARY_PATH  
ORA_OWNR="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 -- startup, shutdown, restart  
# of the instance and listener or usage display  
case "$1" in  
start)  
# Oracle listener and instance startup  
su $ORA_OWNR -lc $ORACLE_HOME/bin/dbstart  
echo "Oracle Start Succesful!OK."  
;;  
stop)  
# Oracle listener and instance shutdown  
su $ORA_OWNR -lc $ORACLE_HOME/bin/dbshut  
echo "Oracle Stop Succesful!OK."  
;;  
reload|restart)  
$0 stop  
$0 start  
;;  
*)  
echo $"Usage: `basename $0` {start|stop|reload|reload}"  
exit 1  
esac  
exit 0 

8.5.设置启动文件权限

[root@oracle ~]$ chmod +x oracle
[root@oracle ~]$ chkconfig --add oracle 
[root@oracle ~]$ chkconfig oracle on

8.6.重启测试

[root@oracle ~]$ reboot

重启后查看监听状态,上图代表启动成功

上一篇 下一篇

猜你喜欢

热点阅读