RHEL 7.6 安装oracle database 18c

2023-10-29 15:58
文章标签 oracle 安装 database rhel 7.6 18c

本文主要是介绍RHEL 7.6 安装oracle database 18c,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 硬件信息

cpu:8core

memory:24G

storage:150G

2 软件环境

2.1 操作系统

rhel-server-7.6-x86_64-dvd

Red Hat Enterprise Linux Server release 7.6 (Maipo)

2.2 软件版本

2.2.1 oracle软件

LINUX.X64_180000_db_home.zip

2.2.2 Opatch补丁

p28822489_180000_Linux-x86-64.zip

3 部署规划

系统安装调整 

[oracle@n1 bin]$ df -h
Filesystem                Size  Used Avail Use% Mounted on
/dev/mapper/root-root00    20G  4.7G   16G  24% /
devtmpfs                   12G     0   12G   0% /dev
tmpfs                      12G  4.0K   12G   1% /dev/shm
tmpfs                      12G   11M   12G   1% /run
tmpfs                      12G     0   12G   0% /sys/fs/cgroup
/dev/sda1                 289M  148M  142M  52% /boot
tmpfs                     2.4G   60K  2.4G   1% /run/user/1000
tmpfs                     2.4G     0  2.4G   0% /run/user/0
/dev/mapper/data-ora       30G   20G   11G  66% /ora
/dev/mapper/data-oradata   50G   69M   50G   1% /oradata
/dev/sr0                  4.2G  4.2G     0 100% /mnt
/dev/mapper/data-arch      10G   33M   10G   1% /arch
tmpfs                     2.4G     0  2.4G   0% /run/user/54321

ora:软件安装目录,oradata:数据文件目录,arch:归档日志目录

安装目录规划

ORACLE_BASE=/ora/oracle
ORACLE_HOME=$ORACLE_BASE/product/18.3.0/dbhome_1mkdir -p /ora/oracle/product/18.3.0/dbhome_1

 注:需提前创建好全路径,否则安装软件时检测不到路径。软件会安装在runInstaller所在路径。

4 安装前准备

4.1 安装18c最低硬件要求

建议不小于2GB的RAM

建议至少1024x768的显示分辨率,从而确保OUI显示正确

建议SWAP:RAM在2.5GB~16GB之间SWAP设置为相同的大小的RAM,RAM大于16GB时SWAP设置为16GB

建议至少留给OracleBase7.5GB空间

4.2 验证硬件信息

RAM:24GB

SWAP:20GB

kernel:3.10.0-957.el7.x86_64

shm:12GB

4.3 系统安装包检查

使用下面命令检查软件包是否安装

rpm -q --qf '%{NAME}-%{VERSION}-%{RELEASE} (%{ARCH})\n' bc \
binutils \
compat-libcap1 \
compat-libstdc++-33 \
glibc \
glibc-devel \
ksh \
libaio \
libaio-devel \
libX11 \
libXau \
libXi \
libXtst \
libXrender-devel \
libXrender \
libgcc \
libstdc++ \
libstdc++-devel \
libxcb \
make \
nfs-utils \
net-tools \
python \
python-configshell \
python-rtslib \
python-six \
smartmontools \
sysstat \
targetcli

安装软件包

yum install bc binutils compat-libcap1 compat-libstdc++-33 glibc glibc-devel ksh libaio libaio-devel libX11 libXau libXi libXtst libXrender-devel libXrender libgcc libstdc++  libstdc++-devel libxcb make nfs-utils net-tools python python-configshell8 python-rtslib python-six  smartmontools sysstat targetcli

RedHat7.*的镜像文件中没有compat-libstdc包,需要手动安装

compat-libstdc++-33-3.2.3-72.el7.i686.rpm

compat-libstdc++-33-3.2.3-72.el7.x86_64.rpm

4.4 确认用户及相应权限设置

/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
passwd oracle

配置环境变量

[oracle@n1 ~]$ more .bash_profile
# .bash_profile# Get the aliases and functions
if [ -f ~/.bashrc ]; then. ~/.bashrc
fi# User specific environment and startup programsPATH=$PATH:$HOME/.local/bin:$HOME/binexport PATHORACLE_SID=eighteenc;export ORACLE_SID  
ORACLE_UNQNAME=eighteenc;export ORACLE_UNQNAME
JAVA_HOME=/usr/local/java; export JAVA_HOME
ORACLE_BASE=/ora/oracle; export ORACLE_BASE
ORACLE_HOME=$ORACLE_BASE/product/18.3.0/dbhome_1; export ORACLE_HOME
ORACLE_TERM=xterm; export ORACLE_TERM
NLS_DATE_FORMAT="YYYY:MM:DDHH24:MI:SS"; export NLS_DATE_FORMAT
#NLS_LANG=american_america.ZHS16GBK; export NLS_LANG
export NLS_LANG=AMERICAN_AMERICA.UTF8
TNS_ADMIN=$ORACLE_HOME/network/admin; export TNS_ADMIN
ORA_NLS11=$ORACLE_HOME/nls/data; export ORA_NLS11
PATH=.:${JAVA_HOME}/bin:${PATH}:$HOME/bin:$ORACLE_HOME/bin:$ORA_CRS_HOME/bin
PATH=${PATH}:/usr/bin:/bin:/usr/bin/X11:/usr/local/bin
export PATH
LD_LIBRARY_PATH=$ORACLE_HOME/lib
LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:$ORACLE_HOME/oracm/lib
LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:/lib:/usr/lib:/usr/local/lib
export LD_LIBRARY_PATH
CLASSPATH=$ORACLE_HOME/JRE
CLASSPATH=${CLASSPATH}:$ORACLE_HOME/jlib
CLASSPATH=${CLASSPATH}:$ORACLE_HOME/rdbms/jlib
CLASSPATH=${CLASSPATH}:$ORACLE_HOME/network/jlib
export CLASSPATH
THREADS_FLAG=native; export THREADS_FLAG
export TEMP=/tmp
export TMPDIR=/tmp
umask 022
export DISPLAY=10.6.0.243:0.0
alias sqlplus='rlwrap sqlplus'
alias rman='rlwrap rman'

4.5 系统参数配置

配置linux内核参数

fs.aio-max-nr = 1048576
fs.file-max = 6815744
#kernel.shmall = 2097152
#kernel.shmmax = 4294967295
kernel.shmall = 4294967296
kernel.shmmax = 12640516096
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

shmall大于或等于shmmax的值,以页为单位。shmmax物理内存大小的一半(以字节为单位) 
用root用户执行sysctl -p 使修改生效。

设置 Oracle 用户的 Shell 限制

oracle  soft  nproc  2047
oracle  hard  nproc  16384
oracle  soft  nofile  1024
oracle  hard  nofile  65536
oracle  soft  stack  10240
oracle  hard  stack  32768
oracle soft memlock 3145728
oracle hard memlock 3145728

设置PAM

session required pam_limits.so

5 安装数据库软件

解压软件包

unzip LINUX.X64_180000_db_home.zip -d database

运行runInstaller.sh

创建配置单实例数据库 or 仅安装软件

单实例数据库安装

安装企业版

编辑ORACLE_BASE

编辑oraInventory目录,配置oracle安装权限组

配置oracle权限组

安装前检查,最大的内存segment的参数推荐12G。

 内存参数shmmax配置为12640516096,检查通过。

 点击install,安装oracle软件

 登录root账号执行脚本

[root@n1 ~]# /ora/oraInventory/orainstRoot.sh
Changing permissions of /ora/oraInventory.
Adding read,write permissions for group.
Removing read,write,execute permissions for world.Changing groupname of /ora/oraInventory to oinstall.
The execution of the script is complete.
[root@n1 ~]# /ora/database/root.sh
Performing root user operation.The following environment variables are set as:ORACLE_OWNER= oracleORACLE_HOME=  /ora/databaseEnter the full pathname of the local bin directory: [/usr/local/bin]: 
The contents of "dbhome" have not changed. No need to overwrite.
The contents of "oraenv" have not changed. No need to overwrite.
The contents of "coraenv" have not changed. No need to overwrite.Entries will be added to the /etc/oratab file as needed by
Database Configuration Assistant when a database is created
Finished running generic part of root script.
Now product-specific root actions will be performed.
Do you want to setup Oracle Trace File Analyzer (TFA) now ? yes|[no] : 
yes
Installing Oracle Trace File Analyzer (TFA).
Log File: /ora/database/install/root_n1_2019-01-25_09-34-27-421115179.log
Finished installing Oracle Trace File Analyzer (TFA)

 oracle 18c软件安装完成

6 创建数据库实例

执行dbca,18c安装启动logo

创建数据库实例

 点选高级配置

 创建单实例数据库,选择Custom Database

 虽然bash_profile已经配置了SID变化,但安装程序好像没有自动识别。

 手动配置SID

文件系统安装,此处显示的ORACLE_HOME为/ora/database。但bash_profile中配置的ORACLE_HOME是/ora/oracle/product/18.3.0/dbhome_1,此问题由于product/18.3.0/dbhome_1不存在,安装软件时候自动配置为runInstaller所在目录。

 配置fra和arch目录

 创建监听程序eighteenc

选择oracle标准组件

 配置oracle 内存管理

 配置oracle数据块大小,默认8K。processes配置为1500

配置数据块字符集 

 配置数据块链接模式

 配置模板schema

 不安装OEM,使用GC同一管理

 配置数据块管理员密码,由于密码复杂度过于简单报错

 密码复杂度:需字母与数字混配

 创建数据库实例,生成脚本和模板文件

 点选Save Response File保存rsp文件

 

 点击finish创建实例

 数据库实例创建ing

 数据库实例创建完成

7 创建监听程序

执行netca

 添加监听程序

 配置监听名:eighteenc

 选择TCP协议

 配置监听端口号:1521

 监听程序配置完成

至此18c安装完成。

oracle进程启动正常。

这篇关于RHEL 7.6 安装oracle database 18c的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/301710

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp