RPM包方式安装Oracle21c的方法详解


Posted in Oracle onAugust 23, 2021

前言

  • 北京时间2021.8.14 Oracle发布了最新的数据库版本Oracle21c, Oracle规划不再发布Oracle20c和Oracle22c, 直接进发布Oracle21c和oracle23c, 其中Oracle21c 没有扩展支持, 支持时间应该不会到2024年,预计使用的客户不会很多.
  • 但是oracle21c的改进事项还是很多的包括了native的block chain 以及 json和javascript的支持.
  • 这里面参考一下云和恩墨的路线图来进行说明, 感谢云和恩墨老师的知识资料
  • 注意oracle将非长期支持的版本命名为创新版本

RPM包方式安装Oracle21c的方法详解

1. 环境准备

本次安装遇到了一个深坑,CentOS8.0安装时很多不兼容性,强行安装也失败了,提示缺少部分java方式,所以没办法,换用的Oracle Enterprise Linux 8.4 安装很顺畅,一个半小时就完成相应的工作了.

Oracle官网下载OEL最新版本.
建议可以讲环境安装的全面一点可以节约很多时间,剩下获取新的包了.
安装好操作系统备用.

Oracle官网下载rpm包, 注意需要选择下载el8的不能选择el7的.

https://download.oracle.com/otn/linux/oracle21c/oracle-database-ee-21c-1.0-1.ol8.x86_64.rpm?AuthParam=1629176797_ffffc61959e496fcaf6ca82b0509e16e
https://yum.oracle.com/repo/OracleLinux/OL8/appstream/x86_64/getPackage/oracle-database-preinstall-21c-1.0-1.el8.x86_64.rpm

注意一个是 oracle本体包,一个是Oracle的preinstall的包,安装的话非常简单.

2. rpm安装.

首先安装preinstall

yun localinstall oracle-database-preinstall-21c-1.0-1.el8.x86_64.rpm

再进行安装ee数据库的安装

yum localinstall oracle-database-ee-21c-1.0-1.ol8.x86_64.rpm

注意事项:

机器需要能够上网,需要能够下载依赖的包
存储空间要足够,避免文件加载失败.

3. 数据库初始化

Oracle的21c与之前的版本完全一致,没有特别的修改,需要设置基本上相同的配置文件即可

3.1 修改初始化脚本, 注意需要修改为自己定义的服务名以及字符集等.
vim /etc/init.d/oracledb_ORCLCDB-21c 
将内容修改为如下:
export ORACLE_HOME=/opt/oracle/product/21c/dbhome_1
export ORACLE_SID=ORA21C
export TEMPLATE_NAME=General_Purpose.dbc
export CHARSET=ZHS16GBK
export PDB_NAME=ORA21CPDB
export LISTENER_NAME=LISTENER
export NUMBER_OF_PDBS=1
export CREATE_AS_CDB=true
3.2 因为修改了自定义的服务名,所以需要复制一个配置文件.
scp /etc/sysconfig/oracledb_ORCLCDB-21c.conf /etc/sysconfig/oracledb_ORA21C-21c.conf 
3.3 执行数据库初始化的脚本
/etc/init.d/oracledb_ORCLCDB-21c configure
# 注意这一步可能耗时比较久一些,需要等待执行成功
# CentOS8 就是这个地方报错,造成后续失败了. 
3.4 修改环境变量,使之能够登录数据库,以及设置NLS_LANG,打开sqlplus可以正常显示中文信息.
vim /etc/profile.d/oracle21c.sh
export  ORACLE_HOME=/opt/oracle/product/21c/dbhome_1
export  PATH=$PATH:/opt/oracle/product/21c/dbhome_1/bin
export  ORACLE_SID=ORA21C
export NLS_LANG='SIMPLIFIED CHINESE_CHINA.AL32UTF8'
保存并且切换用户就会生效.
3.5 登录数据库并且修改oracle系统管理员密码
passwd oracle
su - oracle
sqlplus / as sysdba
alter user system identified by yournewpassword ;
3.6 注意需要添加一个存储过程,能够在开机时自动将pdb打开
CREATE TRIGGER open_all_pdbs
   AFTER STARTUP ON DATABASE
BEGIN
   EXECUTE IMMEDIATE 'alter pluggable database all open';
END open_all_pdbs;
/

4. 设置开机自动启动设置开机自动启动能够节约很多时间.

4.1 修改配置文件
vim /etc/oratab
# 注意将N 修改为 Y
ORA21C:/opt/oracle/product/21c/dbhome_1:Y
4.2 设置启动脚本
vim /usr/bin/oracle.sh
#添加内容如下
#! /bin/bash
#  script  For oracle19c.service
/opt/oracle/product/21c/dbhome_1/bin/lsnrctl start
/opt/oracle/product/21c/dbhome_1/bin/dbstart /opt/oracle/product/19c/dbhome_1
4.3 设置可执行权限
chmod 777 /usr/bin/oracle.sh
4.4 设置一个服务,并且设置为开机自动启动
vim /etc/systemd/system/oracle21c.service
# 添加如下内容

[Unit]
Description=Oracle21c
After=syslog.target network.target

[Service]
LimitMEMLOCK=infinity
LimitNOFILE=65535
Type=oneshot
RemainAfterExit=yes
User=oracle
Environment="ORACLE_HOME=/opt/oracle/product/21c/dbhome_1"
ExecStart=/usr/bin/oracle.sh

[Install]
WantedBy=multi-user.target

# 设置开机启动
systemctl enable oracle21c
4.5 重启机器进行验证.服务可以使用.

5. 修改sqlplus 避免退格键不好用.这一步比较简单了.

下载个 rlwrap的包我这边下载的是
rlwrap-0.43-5.el8.x86_64.rpm
放置到机器上面执行
yum localinstall rlwrap-0.43-5.el8.x86_64.rpm

修改 之前的环境变量,添加一个别名
alias sqlplus='rlwrap sqlplus'
# 注意等号前后不能有空格.

6. 验证一下版本结果界面如下

RPM包方式安装Oracle21c的方法详解 

到此这篇关于RPM包方式安装Oracle21c的方法的文章就介绍到这了,更多相关RPM包安装Oracle21c内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Oracle 相关文章推荐
Oracle设置DB、监听和EM开机启动的方法
Apr 25 Oracle
oracle通过存储过程上传list保存功能
May 12 Oracle
oracle覆盖导入dmp文件的2种方法
May 21 Oracle
Oracle创建只读账号的详细步骤
Jun 07 Oracle
ORACLE数据库应用开发的三十个注意事项
Jun 07 Oracle
ORACLE查看当前账号的相关信息
Jun 18 Oracle
详解Oracle块修改跟踪功能
Nov 07 Oracle
SQL试题 使用窗口函数选出连续3天登录的用户
Apr 24 Oracle
Oracle中DBLink的详细介绍
Apr 29 Oracle
oracle设置密码复杂度及设置超时退出的功能
Jun 28 Oracle
Oracle中日期的使用方法实例
Jul 07 Oracle
oracle连接ODBC sqlserver数据源的详细步骤
Oracle以逗号分隔的字符串拆分为多行数据实例详解
快速学习Oracle触发器和游标
使用Oracle跟踪文件的问题详解
SQL模糊查询报:ORA-00909:参数个数无效问题的解决
ORACLE查看当前账号的相关信息
DBCA命令行搭建Oracle ADG的流程
You might like
用PHP读取flv文件的播放时间长度
2009/09/03 PHP
ThinkPHP3.1新特性之Action参数绑定
2014/06/19 PHP
Yii隐藏URL中index.php的方法
2016/07/12 PHP
PHP获取数组中单列值的方法
2017/06/10 PHP
Laravel如何使用数据库事务及捕获事务失败后的异常详解
2017/10/23 PHP
JavaScript的单例模式 (singleton in Javascript)
2010/06/11 Javascript
JS动态添加option和删除option(附实例代码)
2013/04/01 Javascript
jQuery提示效果代码分享
2014/11/20 Javascript
JS实现可缩放、拖动、关闭和最小化的浮动窗口完整实例
2015/03/04 Javascript
jquery实现鼠标滑过显示二级下拉菜单效果
2015/08/24 Javascript
使用jQuery制作浮动工具栏的实例分享
2016/05/13 Javascript
JS模仿腾讯图片站的图片翻页按钮效果完整实例
2016/06/21 Javascript
微信公众号-获取用户信息(网页授权获取)实现步骤
2016/10/21 Javascript
vue2.0项目中使用Ueditor富文本编辑器示例代码
2017/08/14 Javascript
微信小程序访问豆瓣电影api的实现方法
2019/03/31 Javascript
vue以组件或者插件的形式实现throttle或者debounce
2019/05/22 Javascript
微信小程序版本自动更新的方法
2019/06/14 Javascript
javascript中的this作用域详解
2019/07/15 Javascript
python在windows下实现ping操作并接收返回信息的方法
2015/03/20 Python
python实现的简单FTP上传下载文件实例
2015/06/30 Python
详解如何使用Python编写vim插件
2017/11/28 Python
Python判断文件和字符串编码类型的实例
2017/12/21 Python
Python贪心算法实例小结
2018/04/22 Python
对python3标准库httpclient的使用详解
2018/12/18 Python
python+selenium 鼠标事件操作方法
2019/08/24 Python
python使用re模块爬取豆瓣Top250电影
2020/10/20 Python
CSS3中文字镂空、透明值、阴影效果设置示例小结
2016/03/07 HTML / CSS
SEPHORA新西兰官方网站:购买化妆品和护肤品
2016/12/02 全球购物
PHP中如何创建和修改数组
2012/05/02 面试题
园艺师求职信
2014/04/27 职场文书
群众路线四风问题整改措施
2014/09/27 职场文书
小学生节水倡议书
2015/04/29 职场文书
个人工作决心书
2015/09/22 职场文书
廉洁自律承诺书2016
2016/03/25 职场文书
2016年“9.22”世界无车日活动小结
2016/04/05 职场文书
读《庄子》有感:美而不自知
2019/11/06 职场文书