一、准备工作
1、关闭selinux
getenforce或者sestatus -vsetenforce 0vim /etc/selinux/configSELINUX=disabled2、关闭firewalld 安装iptables
systemctl stop firewalld.service systemctl disable firewalld.service yum -y install iptables-services
systemctl restart iptables.service systemctl enable iptables.service 3、创建用户
groupadd oinstall
groupadd dba useradd -g oinstall -G dba -m oraclepasswd oracle 4、创建安装目录,解压文件
这里是安装到根下ora目录,权限755,可以给高点如777mkdir -p /ora/oracleunzip -d /ora/ linux.x64_11gR2_database_1of2.zipunzip -d /ora/ linux.x64_11gR2_database_2of2.zipchown -R oracle:oinstall /orachmod 755 -R /ora
ora下各个目录的作用:database
oracle oraInventory 5、安装oracle所需依赖和桌面组件
yum -y install binutils compat compat-libstdc gcc gcc-c++ glibc glibc-devel ksh libaio libaio-devel libgcc libstdc++ libstdc++-devel libXi libXtst make sysstat unixODBC unixODBC-devel
yum -y groupinstall "GNOME Desktop" "Graphical Administration Tools"
6、将服务器名写入到hosts文件,可以测试ping sername 是否返回127.0.0.1
echo '127.0.0.1 oracledb localhost localhost.localdomain' >> /etc/hostsping -c 3 oracledb
PING oracledb (127.0.0.1) 56(84) bytes of data.
64 bytes from localhost (127.0.0.1): icmp_seq=1 ttl=64 time=0.030 ms
64 bytes from localhost (127.0.0.1): icmp_seq=2 ttl=64 time=0.043 ms
64 bytes from localhost (127.0.0.1): icmp_seq=3 ttl=64 time=0.041 ms
--- oracledb ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 1999ms
rtt min/avg/max/mdev = 0.030/0.038/0.043/0.005 ms
7、修改内核(/etc/sysctl.conf),增加或修改以下内容
vim /etc/sysctl.conf
fs.aio-max-nr = 1048576fs.file-max = 6815744kernel.shmall = 2097152kernel.shmmax = 4294967295kernel.shmmni = 4096kernel.sem = 250 32000 100 128net.ipv4.ip_local_port_range = 9000 65500net.core.rmem_default = 262144net.core.rmem_max = 4194304net.core.wmem_default = 262144net.core.wmem_max = 1048576内核参数需要注意,shmall 和shmmax 的值由服务器内存决定。(不过这个参数设置博主我现在也是一知半解,没完全搞明白,查了半天意思如下:)
kernel.shmall :
该参数控制可以使用的共享内存的总页数。Linux共享内存页大小为4KB,共享内存段的大小都是共享内存页大小的整数倍。一个共享内存段的最大大小是16G,那么需要共享内存页数是16GB/4KB=16777216KB/4KB=4194304(页),也就是64Bit系统下16GB物理内存,设置kernel.shmall = 4194304 符合要求。
kernel.shmmax:
是核心参数中最重要的参数之一,用于定义单个共享内存段的最大值。64位linux系统:可取的最大值为物理内存值-1byte,建议值为多于物理内存的一半,例如,如果为16GB物理内存,可取1610241024*1024-1=17179869183。
kernel.shmmni:
该参数是共享内存段的最大数量。shmmni缺省值4096,一般肯定是够用了。
kernel.sem = 250 32000 100 128 的意思是:
250是参数semmsl的值,表示一个信号量集合中能够包含的信号量最大数目。
32000是参数semmns的值,表示系统内可允许的信号量最大数目。
100是参数semopm的值,表示单个semopm()调用在一个信号量集合上可以执行的操作数量。
128是参数semmni的值,表示系统信号量集合总数。
完成后使用命令sysctl -p
8、修改认证模块
vim /etc/security/limits.conf
oracle soft nproc 131072
oracle hard nproc 131072
oracle soft nofile 131072
oracle hard nofile 131072
oracle soft core unlimited
oracle hard core unlimited
oracle soft memlock 50000000
oracle hard memlock 50000000
9、修改用户登录认证
vim /etc/pam.d/login
session required /lib64/security/pam_limits.so
session required pam_limits.so
注意了,很多博文都是照搬抄袭,都是写的/lib/security/pam_limits.so 一般咱都是64位系统,64位系统需要设置为/lib64/security/pam_limits.so 否则重启服务器后就会出现命令行无法登录,但是通过桌面方式能登录的情况。
10、设置环境变量
Ⅰ、ORACLE_HOME 设置为安装目录product下默认目录
vim /etc/profile
*按i进入编辑模式*
#oracle
export ORACLE_HOME=/ora/oracle/product/11.2.0/db_1
export ORACLE_SID=orcl
if [ $USER = "oracle" ]; then
if [ $SHELL = "/bin/ksh" ]; then
ulimit -p 16384
ulimit -n 65536
else
ulimit -u 16384 -n 65536
fi
fi
Ⅱ、修改oracle用户环境变量
vim /home/oracle/.bash_profile
*按i进入编辑模式*
export ORACLE_BASE=/ora/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
export ORACLE_SID=orcl
export ORACLE_TERM=xterm
export PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
二、通过桌面方式安装oracle
1、使用oracle用户登录桌面,打开终端运行安装程序。
cd /ora/database./runInstaller
注意:oracle中文语言会出现乱码,所以系统最好设置为en 英文,如果系统安装的时候选择了中文,那么oracle用户登录的时候也要修改用户语言为英文才能正常安装。
2、安装过程是都有相应提示的,并且鼠标直接点就完了
1):订阅邮件这些就直接跳过不填了。

2):这里选择忽略更新(没有这个选项则跳过)。

3):选择仅安装数据库,稍后再配置初始化数据。

4):选择单实例安装。

5):语言,选择英文。选中文后面容易出问题。

6):企业版

7):这里就出现最开始创建的相应目录信息了,会自动读取。

8):下一步

9):选择group 组为之前创建好的oinstall

10):先决条件检查
安装的过程中可能会出现如下的一些警告信息,如提示semmni为0 的问题,该问题一直没有找到原因,我们在上面修改内核的过程中就已经调整了kernel.sem = 250 32000 100 128 但是检测无法通过(暂时无解)
其他的一些依赖组件提示,其实我们已经大部分安装好了,只是centos7上yum安装的依赖包要比oracle 11g 所需的包更新,版本更高,所以大部分可以直接忽略这些提示(勾选 ignore all)。

11):安装到最后的时候会出现一个提示:需要用root权限执行2个shell脚本,那么我们在之前的root用户终端下运行提示中的对应脚本文件即可。
