一 环境准备
安装包: Linux.x64_11gR2_database_1of2.zip Linux.x64_11gR2_database_2of2.zip
二 安装 Oracle 准备
2.1 用户名 / 组建立
- [root@oracle ~]# vi /etc/hosts
- 172.24.8.30 oracle # 将 localhost 修改为相应的主机名
- [root@oracle ~]# groupadd oinstall # 创建用户组 oinstall
- [root@oracle ~]# groupadd dba # 创建用户组 dba
- [root@oracle ~]# useradd -g oinstall -g dba -m oracle # 创建 oracle 用户, 并加入到 oinstall 和 dba 用户组 0
- [root@oracle ~]# echo x120952576 | passwd --stdin oracle # 设置 Oracle 用户密码
2.2 相关目录创建
- [root@oracle ~]# mkdir -p /data/oracle #oracle 数据库安装目录
- [root@oracle ~]# mkdir -p /data/oraInventory #oracle 数据库配置文件目录
- [root@oracle ~]# mkdir -p /data/database #oracle 数据库软件包解压目录
- [root@oracle ~]# chown -R oracle:oinstall /data/oracle/
- [root@oracle ~]# chown -R oracle:oinstall /data/oraInventory/
- [root@oracle ~]# chown -R oracle:oinstall /data/database/ #设置目录所有者为 oinstall 用户组的 oracle 用户
提示: oracle 默认不支持 CentOS 系统安装, 需要如下修改
- [root@oracle data]# vi /etc/RedHat-release
- RedHat-7
2.3 基础依赖包安装
根据 Oracle 官方给出参考: https://docs.oracle.com/cd/E11882_01/install.112/e47689/pre_install.htm#BABCFJFG
- binutils-2.23.52.0.1-12.el7.x86_64
- compat-libcap1-1.10-3.el7.x86_64
- compat-libstdc++-33-3.2.3-71.el7.i686
- compat-libstdc++-33-3.2.3-71.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
依次 yum 安装即可, 也可高于以上建议版本:
yum install gcc* gcc-* gcc-c++-* glibc-devel-* glibc-headers-* compat-libstdc* libstdc* elfutils-libelf-devel* libaio-devel* sysstat* unixODBC-* pdksh-*.
swap 要求 2.67G
2.4 防火墙及 SELinux 设置
- [root@oracle ~]# systemctl stop firewalld.service
- [root@oracle ~]# systemctl disable firewalld.service
- [root@oracle ~]# setenforce 0
- [root@oracle ~]# vi /etc/selinux/config
- SELINUX=disabled
2.5 修改内核参数
- [root@oracle ~]# vi /etc/sysctl.conf
- net.ipv4.icmp_echo_ignore_broadcasts = 1
- net.ipv4.conf.all.rp_filter = 1
- fs.file-max = 6815744 # 设置最大打开文件数
- fs.aio-max-nr = 1048576
- kernel.shmall = 2097152 # 共享内存的总量
- kernel.shmmax = 2147483648 #最大共享内存的段大小
- kernel.shmmni = 4096 # 整个系统共享内存端的最大数
- kernel.sem = 250 32000 100 128
简要描述这四个参数
SEMMSL: 每个信号集的最大信号数量
SEMMNS: 系统信号量 (非信号集) 最大数量
SEMOPM: 每次 semop 系统调用可执行的信号操作数
SEMMNI: 系统信号量集最大数量
- 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= 1048576
- [root@oracle ~]# sysctl -p # 使配置生效
2.6 提高软件运行性能
对 oracle 用户设置限制, 提高软件运行性能
- [root@oracle ~]# vi /etc/security/limits.conf
- @student - maxlogins 4
- oracle soft nproc 2047
- oracle hard nproc 16384
- oracle soft nofile 1024
- oracle hard nofile 65536
- # End of file
2.7 修改环境变量
- [root@oracle ~]# vi /home/oracle/.bash_profile # 修改 Oracle 用户的环境变量
- export ORACLE_BASE=/data/oracle #oracle 数据库安装目录
- export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1 #oracle 数据库路径
- export ORACLE_SID=orcl #oracle 启动数据库实例名
- export ORACLE_TERM=xterm #xterm 窗口模式安装
- export PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH # 添加系统环境变量
- export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib # 添加系统环境变量
- export LANG=en_US # 防止安装过程出现乱码
- export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK # 设置 Oracle 客户端字符集
- [root@oracle ~]# source /home/oracle/.bash_profile
三 Oracle 安装
3.1 解压安装包
- [root@oracle ~]$ cd /usr/local/src #进入 / usr/local/src 目录
- [root@oracle src]$ ls
- Linux.x64_11gR2_database_1of2.zip Linux.x64_11gR2_database_2of2.zip
- [root@oracle src]$ unzip Linux.x64_11gR2_database_1of2.zip -d /data/database/ #解压
- [root@oracle src]$ unzip Linux.x64_11gR2_database_2of2.zip -d /data/database/ #解压
- [root@oracle src]$ su root
- Password:
- [root@oracle src]# chown -R oracle:oinstall /data/database/database/
3.2 启动 Oracle 安装
采用 oracle 用户进入图形界面, 并启动安装程序.
- [oracle@oracle ~]# su oracle
- [oracle@oracle ~]$ cd /data/database/database/
- [oracle@oracle database]$ ./runInstaller
注意:
1: 以上必须进入图形界面之后操作;
2: 若出现以下报错 --
Could not execute auto check for display colors using command /usr/bin/xdpyinfo.
需要使用 root 用户执行以下操作, 之后切换回 oracle 用户再次执行以上 runInstaller 即可.
- xhost + 172.24.8.30
- xhost +SI:localuser:oracle
email 可不填.
选择创建和配置数据库选项, 下一步.
选择桌面学习版
将字符设置为 utf8, 密码需要大小写数字结合.
勾选 "ignore all"
提示: failed 依次每一个解决即可.
注意: 安装程序对环境进行检查, 由于 CentOS 的 32bit 程序包都是 i686 的, 而 Oracle 要求 i386, 所以此处会失败, 这确保依赖包存在的情况下忽略即可.
漫长的等待(基本上可以睡个午觉)
安装成功
四 添加侦听端口
4.1 配置侦听程序
使用 oracle 用户执行 --
[oracle@oracle ~]$ netca
4.2 配置另一侦听器
测试成功
五 其他环境优化
5.1 环境修改
- [root@oracle ~]# vi /data/oracle/product/11.2.0/dbhome_1/sqlplus/admin/glogin.sql
- define_editor=VIM # 定义编辑器为 VIM
- set linesize 160 # 设置一行显示的字符
- set pagesize 100 # 设置一页显示的行数
- set sqlprompt '_user@ _connect_identifier>' # 设置提示符
5.2 支持键盘方向键操作
提示: 默认 oracle 不支持方向键操作, 需要安装 rlwrap 插件.
采用编译安装 rlwrap-0.37.tar, 过程略.
若报错如下 --
则需要 yum 安装以下两个 rpm 包之后再次编译安装 --
- [root@oracle ~]# yum -y install libtermcap-devel readline-devel
- [root@oracle ~]# vi /home/oracle/.bash_profile
- alias sqlplus='rlwrap sqlplus'
- alias rman='rlwrap rman'
- [root@oracle rlwrap-0.37]# su - oracle
- [oracle@oracle ~]$ source .bash_profile
5.3 密码设置
- [oracle@oracle ~]$ sqlplus / as sysdba
- SYS@ orcl>alter profile default limit password_life_time unlimited; #oracle 默认 180 天过期, 可设置口令永不过期
来源: http://www.linuxidc.com/Linux/2019-03/157531.htm