前言
相信大家第一次接触 Oracle,大都是在 windows 上安装,比较方便快捷,基本上是一直下一步就可以安装成功。然而企业级的数据库,基本上都是安装在 Linux 服务器上,安全且高效。
没接触 Linux 的朋友不用害怕,跟着本篇文章一步步操作,安装 Oracle 如喝水般简单且标准。
下面我就来手把手教大家如何在 Linux 上安装 Oracle 数据库。

前期准备
Linux系统安装
安装 Linux 服务器可选择:Centos,Redhat,Oracle Linux。
📢 注意: 上述 Linux 安装包 和 Oracle 安装包 可点击链接跳转获取:
Linux 安装包: https://mp.weixin.qq.com/s/vqhPRNwSeiaTsiWHo0GKVA
Oracle 安装包: https://mp.weixin.qq.com/s/NLsI_sRLFGRQhi6r1yD9sw

📢 注意: Linux 系统的安装本文不做详细演示!
Linux远程连接工具
本文将使用 XShell 和 Xftp 工具,安装包可以在官网下载,也可私信博主获取。
其他工具也可以,比如:putty,SecureCRT 等等工具。
本篇博客将演示 RedHat Linux 7.6 版本安装 Oracle 11GR2 版本数据库。
Linux主机配置
安装 Linux
操作系统的步骤此处省略,主机内存 2G ,硬盘 50G 即可。
使用XShell工具连接Linux主机root用户:

主机名配置
如果安装时没有配置主机名,或者想要修改主机名,可以通过以下命令修改:
1
| hostnamectl set-hostname orcl
|

网络配置
如果安装时没有配置网络,或者想要修改网络,可以通过以下命令修改:
1 2
| nmcli connection modify eth0 ipv4.addresses 10.211.55.188/24 ipv4.gateway 10.211.55.1 ipv4.method manual autoconnect yes nmcli connection up eth0
|

配置Hosts文件
根据上面配置好的主机名和 IP,配置 hosts 文件:
1 2 3 4 5 6
| cat <<EOF >>/etc/hosts ##OracleBegin## ##Public IP 10.211.55.188 orcl ##OracleEnd## EOF
|

防火墙配置
1 2
| systemctl stop firewalld systemctl disable firewalld
|

Selinux配置
selinux修改后需要重启主机生效:
1
| sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
|

ISO镜像源配置
📢 注意: 需要先挂载主机镜像!
Parallels Desktop 挂载 Linux 主机镜像:

VMware Workstation 挂载 Linux 镜像:
1 2 3 4 5 6 7 8
| mount /dev/cdrom /mnt cat <<EOF>/etc/yum.repos.d/local.repo [local] name=local baseurl=file:///mnt gpgcheck=0 enabled=1 EOF
|

安装Oracle依赖包
如下依赖包从Oracle官方文档推荐获取:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
| yum install -y bc \ binutils \ compat-libcap1 \ compat-libstdc++-33 \ gcc \ gcc-c++ \ elfutils-libelf \ elfutils-libelf-devel \ glibc \ glibc-devel \ ksh \ libaio \ libaio-devel \ libgcc \ libstdc++ \ libstdc++-devel \ libxcb \ libX11 \ libXau \ libXi \ libXtst \ libXrender \ libXrender-devel \ make \ net-tools \ nfs-utils \ smartmontools \ sysstat \ e2fsprogs \ e2fsprogs-libs \ fontconfig-devel \ expect \ unzip \ openssh-clients \ readline* \ psmisc --skip-broken
|
检查是否安装成功:
1
| rpm -q bc binutils compat-libcap1 compat-libstdc++-33 gcc gcc-c++ elfutils-libelf elfutils-libelf-devel glibc glibc-devel ksh libaio libaio-devel libgcc libstdc++ libstdc++-devel libxcb libX11 libXau libXi libXtst libXrender libXrender-devel make net-tools nfs-utils smartmontools sysstat e2fsprogs e2fsprogs-libs fontconfig-devel expect unzip openssh-clients readline
|

Linux7需要手动安装compat-libstdc++依赖包:
1
| rpm -ivh compat-libstdc++-33-3.2.3-72.el7.x86_64.rpm
|

配置ZeroConf
1 2 3 4 5 6 7 8 9 10 11 12
| systemctl stop avahi-daemon.socket systemctl stop avahi-daemon.service systemctl disable avahi-daemon.service systemctl disable avahi-daemon.socket
cat <<EOF >>/etc/sysconfig/network #OracleBegin NOZEROCONF=yes #OracleEnd EOF
|

关闭透明大页和numa
1 2
| sed -i 's/quiet/quiet transparent_hugepage=never numa=off/' /etc/default/grub grub2-mkconfig -o /boot/grub2/grub.cfg
|

配置系统参数文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
| memTotal=$(grep MemTotal /proc/meminfo | awk '{print $2}') totalMemory=$((memTotal / 2048)) shmall=$((memTotal / 4)) if [ $shmall -lt 2097152 ]; then shmall=2097152 fi shmmax=$((memTotal * 1024 - 1)) if [ "$shmmax" -lt 4294967295 ]; then shmmax=4294967295 fi echo $shmall echo $shmmax
cat <<EOF >>/etc/sysctl.conf #OracleBegin ##shmmal's Calculation formula: physical memory 8G:(8*1024*1024*1024)/4096=2097152 ##shmmax's Calculation formula: physical memory 8G:(8/2)*1024*1024*1024 -1=4294967295 fs.aio-max-nr = 1048576 fs.file-max = 6815744 kernel.shmall = $shmall kernel.shmmax = $shmmax 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 = 1048576 EOF
sysctl -p
|


配置系统资源限制
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| cat <<EOF >>/etc/security/limits.conf #OracleBegin oracle soft nofile 1024 oracle hard nofile 65536 oracle soft stack 10240 oracle hard stack 32768 oracle soft nproc 2047 oracle hard nproc 16384 oracle hard memlock 134217728 oracle soft memlock 134217728 #OracleEnd EOF
cat <<EOF >>/etc/pam.d/login #OracleBegin session required pam_limits.so session required /lib64/security/pam_limits.so #OracleEnd EOF
|


创建用户和组
1 2 3 4 5 6
| /usr/sbin/groupadd -g 54321 oinstall /usr/sbin/groupadd -g 54322 dba /usr/sbin/groupadd -g 54323 oper
/usr/sbin/useradd -u 54321 -g oinstall -G dba,oper oracle echo oracle | passwd --stdin oracle
|

创建Oracle安装目录
1 2 3 4 5 6
| mkdir -p /u01/app/oracle/product/11.2.0/db mkdir -p /u01/app/oraInventory mkdir -p /oradata chown -R oracle:oinstall /oradata chown -R oracle:oinstall /u01/app chmod -R 775 /u01/app
|

配置用户环境变量
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| cat <<EOF >>/home/oracle/.bash_profile ################OracleBegin######################### umask 022 export TMP=/tmp export TMPDIR=\$TMP export NLS_LANG=AMERICAN_AMERICA.AL32UTF8 export ORACLE_BASE=/u01/app/oracle export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db export ORACLE_HOSTNAME=orcl export ORACLE_TERM=xterm export TNS_ADMIN=\$ORACLE_HOME/network/admin export LD_LIBRARY_PATH=\$ORACLE_HOME/lib:/lib:/usr/lib export ORACLE_SID=orcl export PATH=/usr/sbin:\$PATH export PATH=\$ORACLE_HOME/bin:\$ORACLE_HOME/OPatch:\$PATH alias sas='sqlplus / as sysdba' export PS1="[\`whoami\`@\`hostname\`:"'\$PWD]\$ ' EOF
|

Oracle软件安装
Oracle软件包上传
1 2 3
| [root@orcl soft] -rw-r--r--. 1 root root 1395582860 May 31 16:56 p13390677_112040_Linux-x86-64_1of7.zip -rw-r--r--. 1 root root 1151304589 May 31 16:56 p13390677_112040_Linux-x86-64_2of7.zip
|

解压Oracle软件安装包
需要按顺序解压1,2安装包:
1 2 3 4 5 6
| cd /soft unzip -q p13390677_112040_Linux-x86-64_1of7.zip unzip -q p13390677_112040_Linux-x86-64_2of7.zip
chown -R oracle:oinstall /soft
|

安装VNC软件
1 2 3 4 5
| yum install -y tigervnc*
su - oracle vncserver
|

连接VNC远程工具或者直接打开虚拟机图形化界面

右键打开终端工具:

进入 /soft/database 开始安装 Oracle 软件:
1
| ./runInstaller -jreLoc /etc/alternatives/jre_1.8.0
|

不接收 Oracle 邮件推送:

不更新 Oracle:

只安装 Oracle 软件:

单实例安装:

选择企业版:

选择安装目录:


选择安装用户组:

Oracle 安装前必要检查:

上传 pdksh-5.2.14-37.el5.x86_64.rpm 依赖包并安装:
1 2
| rpm -e ksh-20120801-142.el7.x86_64 rpm -ivh pdksh-5.2.14-37.el5.x86_64.rpm
|

点击再次检查,忽略 Swap 警告:




解决方案:
1 2
| su - oracle sed -i 's/^\(\s*\$(MK_EMAGENT_NMECTL)\)\s*$/\1 -lnnz11/g' $ORACLE_HOME/sysman/lib/ins_emagent.mk
|
执行完点击retry重试:

执行 root 脚本:

root用户下执行脚本:
1 2
| /u01/app/oraInventory/orainstRoot.sh /u01/app/oracle/product/11.2.0/db/root.sh
|



安装完成后,重启主机。
创建数据库
打开监听
1 2 3
| su - oracle lsnrctl start lsnrctl status
|

连接VNC远程工具或者直接打开虚拟机图形化界面

创建数据库:

选择自定义模式:

输入实例名:

这里填写数据库实例名称和 dbname,本次填写 orcl。

不安装EM工具。

这里输入SYS和SYSTEM用户的密码,需要记住。

这里选择前面建好的/oradata目录用来存放数据文件。

不开启闪回日志,不开启归档日志,可以建好库之后再手动修改。


数据库内存分配,选择手动分配,占用物理内存70%左右。

block_size根据实际情况选择,一旦建库无法修改,默认8K。

字符集根据需要进行选择,默认AL32UTF8。




等待建库完成即可。

连接数据库
确保监听正常启动,并监听数据库:

通过数据库主机连接
1 2 3 4 5 6 7 8 9 10 11 12 13
| su - oracle sqlplus / as sysdba select sysdate from dual;
create user test identified by test; grant dba to test; conn test/test
create table test (id number not null,name varchar2(100)); insert into test values (1,'lucifer'); commit;
|
通过PL/SQL连接test用户


至此,Oracle数据库已经安装完毕。