【纯干货】Oracle 19C RU 19.25 发布,如何快速升级和安装? ...

种地  金牌会员 | 2024-10-19 08:50:07 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 878|帖子 878|积分 2634

大家好,这里是公众号 Lucifer三思而后行,分享一些学习国产数据库路上的知识和经验。
  
  
前言

今天一早打开邮箱收到 Oracle 的邮件,开头内容如下:
  1. October 15, 2024
  2. Oracle Critical Patch Update for October 2024
  3. Dear Oracle Customer,
  4. Critical Patch Update October 2024 was released on October 15, 2024.
  5. Oracle strongly recommends applying the patches as soon as possible.
复制代码
原来是 Oracle 第四序度补丁发布了,Oracle 19C 补丁限时下载链接,明天删除!!!


  • 《Oralce 19C 19.25 RU 20241015 Linux 最新补丁(GI+DB+OPatch+OJVM)》
仅开放 1 天下载,逾期删除。
介绍

上班后,打开 MOS 查看了一下,果然更新了:
数据库版本补丁范例补丁版本补丁编号发布日期Oracle 11GR2Grid**15-Oct-2024Oracle 11GR2Database**15-Oct-2024Oracle 11GR2OJVM11.2.0.4.241015 (Oct 2024) OJVM Component Patch Set UpdatePatch 3687878115-Oct-2024Oracle 12CR2Grid12.2.0.1.241015 (Oct 2024) GI Release UpdatePatch 3694030515-Oct-2024Oracle 12CR2Database12.2.0.1.241015 (Oct 2024) Database Release UpdatePatch 3694140015-Oct-2024Oracle 12CR2OJVM12.2.0.1.241015 (Oct 2024) OJVM Release UpdatePatch 3687873715-Oct-2024Oracle 19CGridDatabase Release Update 19.25.0Patch 3691259715-Oct-2024Oracle 19CDatabaseGI Release Update 19.25.0Patch 3691669015-Oct-2024Oracle 19COJVMOJVM Release Update 19.25.0Patch 3687869715-Oct-2024 老样子,11GR2 没有更新 Grid 和 DB 的补丁,其他版本补丁均正常发布。
这里顺带分享一下几个 MOS 补丁的下载链接:


  • Patch 6880880
  • Assistant: Download Reference for Oracle Database/GI Update, Revision, PSU, SPU(CPU), Bundle Patches, Patchsets and Base Releases (Doc ID 2118136.2)
  • Primary Note for Database Proactive Patch Program (Doc ID 888.1)
  • Database 11.2.0.4 Proactive Patch Information (Doc ID 2285559.1)
  • Database 12.2.0.1 Proactive Patch Information (Doc ID 2285557.1)
  • Oracle Database 19c Proactive Patch Information (Doc ID 2521164.1)
有 MOS 账号的小同伴可以直接点击链接进行下载了。
19.25 RU 补丁安装

环境信息:
脚色IP地址数据库版本CDB名PDB名源端192.168.6.13619.3orclcdbtestpdb 本文数据库环境均使用 Oracle 一键安装脚本部署:
   脚本下载:Oracle一键安装脚本
作者微信:Lucifer-0622
  环境预备

为了演示补丁安装,使用 Oracle 一键安装脚本快速安装一套 Oracle 19C 无补丁测试环境:
  1. ./OracleShellInstall -lf ens192 `# local ip ifname`\
  2. -n rhel8 `# hostname`\
  3. -op oracle `# oracle password`\
  4. -d /u01 `# software base dir`\
  5. -ord /oradata `# data dir`\
  6. -o orclcdb `# dbname`\
  7. -pdb testpdb `# pdbname`\
  8. -dp oracle `# sys/system password`\
  9. -ds AL32UTF8 `# database character`\
  10. -ns AL16UTF16 `# national character`\
  11. -redo 100 `# redo size`\
  12. -opd Y `# optimize db`
复制代码
一键安装过程如下:
  1.    ███████                             ██          ████████ ██               ██  ██ ██                    ██              ██  ██
  2.   ██░░░░░██                           ░██         ██░░░░░░ ░██              ░██ ░██░██                   ░██             ░██ ░██
  3. ██     ░░██ ██████  ██████    █████  ░██  █████ ░██       ░██       █████  ░██ ░██░██ ███████   ██████ ██████  ██████   ░██ ░██
  4. ░██      ░██░░██░░█ ░░░░░░██  ██░░░██ ░██ ██░░░██░█████████░██████  ██░░░██ ░██ ░██░██░░██░░░██ ██░░░░ ░░░██░  ░░░░░░██  ░██ ░██
  5. ░██      ░██ ░██ ░   ███████ ░██  ░░  ░██░███████░░░░░░░░██░██░░░██░███████ ░██ ░██░██ ░██  ░██░░█████   ░██    ███████  ░██ ░██
  6. ░░██     ██  ░██    ██░░░░██ ░██   ██ ░██░██░░░░        ░██░██  ░██░██░░░░  ░██ ░██░██ ░██  ░██ ░░░░░██  ░██   ██░░░░██  ░██ ░██
  7. ░░███████  ░███   ░░████████░░█████  ███░░██████ ████████ ░██  ░██░░██████ ███ ███░██ ███  ░██ ██████   ░░██ ░░████████ ███ ███
  8.   ░░░░░░░   ░░░     ░░░░░░░░  ░░░░░  ░░░  ░░░░░░ ░░░░░░░░  ░░   ░░  ░░░░░░ ░░░ ░░░ ░░ ░░░   ░░ ░░░░░░     ░░   ░░░░░░░░ ░░░ ░░░
  9. 注意:本脚本仅用于新服务器上实施部署数据库使用,严禁在已运行数据库的主机上执行,以免发生数据丢失或者损坏,造成不可挽回的损失!!!                                                                                 
  10. 请选择安装模式 [单机(si)/单机ASM(sa)/集群(rac)] : si
  11. 数据库安装模式: single                                                                           
  12. 请选择数据库版本 [11|12|19|21|23] : 19
  13. 数据库版本:     19                                                                              
  14. OracleShellInstall 开始安装,详细安装过程可查看日志: tail -2000f /soft/print_shell_install_20241016110850.log                                                                                 
  15. 正在进行安装前检查,请稍等......                                                                                 
  16. 正在检测安装包 /soft/LINUX.X64_193000_db_home.zip 的 MD5 值是否正确,请稍等......                                                                                 
  17. 正在配置本地软件源......已完成 (耗时: 0 秒)
  18. 正在获取操作系统信息......已完成 (耗时: 2 秒)
  19. 正在安装依赖包......已完成 (耗时: 130 秒)
  20. 正在禁用防火墙......已完成 (耗时: 1 秒)
  21. 正在禁用 selinux......已完成 (耗时: 1 秒)
  22. 正在配置 nsyctl......已完成 (耗时: 0 秒)
  23. 正在配置主机名和 hosts 文件......已完成 (耗时: 0 秒)
  24. 正在创建用户和组......已完成 (耗时: 1 秒)
  25. 正在创建安装目录......已完成 (耗时: 0 秒)
  26. 正在配置透明大页 && NUMA && 磁盘 IO 调度器......已完成 (耗时: 4 秒)
  27. 正在配置操作系统参数 sysctl......已完成 (耗时: 1 秒)
  28. 正在配置 RemoveIPC......已完成 (耗时: 1 秒)
  29. 正在配置用户限制 limit......已完成 (耗时: 1 秒)
  30. 正在配置 shm 目录......已完成 (耗时: 1 秒)
  31. 正在安装 rlwrap 插件......已完成 (耗时: 11 秒)
  32. 正在配置用户环境变量......已完成 (耗时: 1 秒)
  33. 正在解压 Oracle 安装包以及补丁......已完成 (耗时: 84 秒)
  34. 正在安装 Oracle 软件以及补丁......已完成 (耗时: 152 秒)
  35. 正在创建监听......已完成 (耗时: 3 秒)
  36. 正在创建数据库......已完成 (耗时: 1260 秒)
  37. 正在优化数据库......已完成 (耗时: 37 秒)
  38. 恭喜!Oracle 一键安装执行完成 (耗时: 1699 秒),现在是否重启主机:[Y/N] Y
  39. 正在重启当前节点主机......
复制代码
安装好的环境为 19C 无补丁数据库版本:
  1. [oracle@rhel8:/home/oracle]$ sqlplus -v
  2. SQL*Plus: Release 19.0.0.0.0 - Production
  3. Version 19.3.0.0.0
  4. [oracle@rhel8:/home/oracle]$ opatch lspatches
  5. 29585399;OCW RELEASE UPDATE 19.3.0.0.0 (29585399)
  6. 29517242;Database Release Update : 19.3.0.0.190416 (29517242)
  7. OPatch succeeded.
复制代码
下面演示一下 Oracle 19C RU 19.25 补丁的安装步骤。
README

首先须要查看补丁的 README 文件(解压补丁后即可获得),其中补丁的前置要求如下:


  • You must use the OPatch utility version 12.2.0.1.43 or later to apply this patch.
  • If you are using a Data Guard Physical Standby database, you must install this patch on both the primary database and the physical standby database.
  • If this is an Oracle RAC environment, install this patch using the OPatch rolling (no downtime) installation method as this patch is rolling RAC installable.
  • If this is not a RAC environment, shut down all instances and listeners associated with the Oracle home that you are updating.
翻译一下就是:


  • OPatch 版本大于 12.2.0.1.43
  • 有 DG 的环境,DG 也要打补丁
  • RAC 环境可以滚动升级
  • 单机环境须要关闭全部 oracle 相关的服务
升级 OPatch

查看当前数据库的 Opatch 版本:
  1. [oracle@rhel8:/home/oracle]$ opatch version
  2. OPatch Version: 12.2.0.1.17
  3. OPatch succeeded.
复制代码
opatch 版本低于 43,须要下载最新的 OPatch 补丁更换,在 Patch 6880880 下载对应版本的补丁:

下载后上传到数据库主机,解压更换即可(这一步不须要停机,可以在线利用):
  1. ## 这里我上传到 /soft 目录,所以需要对目录进行授权
  2. [root@rhel8:/root]# chown -R oracle:oinstall /soft/
  3. ## oracle 用户静默解压 opatch 到 ORACLE_HOME 目录下
  4. [oracle@rhel8:/home/oracle]$ cd /soft/
  5. [oracle@rhel8:/soft]$ unzip -qo p6880880_190000_Linux-x86-64.zip -d $ORACLE_HOME
  6. ## 查看替换后的 OPatch 版本
  7. [oracle@rhel8:/soft]$ opatch version
  8. OPatch Version: 12.2.0.1.44
  9. OPatch succeeded.
复制代码
升级完 OPatch 版本之后,须要进行安装前补丁辩论检查。
辩论检查

首先须要上传 RU 补丁并解压:
  1. ## 这里我上传到 /soft 目录,所以需要对目录进行授权
  2. [root@rhel8:/root]# chown -R oracle:oinstall /soft/
  3. ## oracle 用户静默解压 RU 补丁包
  4. [oracle@rhel8:/soft]$ unzip -q p36912597_190000_Linux-x86-64.zip
  5. [oracle@rhel8:/soft]$ cd 36912597/
  6. ## 检查冲突,一般是没有问题的
  7. [oracle@rhel8:/soft/36912597]$ opatch prereq CheckConflictAgainstOHWithDetail -ph ./
  8. Oracle Interim Patch Installer version 12.2.0.1.44
  9. Copyright (c) 2024, Oracle Corporation.  All rights reserved.
  10. PREREQ session
  11. Oracle Home       : /u01/app/oracle/product/19.3.0/db
  12. Central Inventory : /u01/app/oraInventory
  13.    from           : /u01/app/oracle/product/19.3.0/db/oraInst.loc
  14. OPatch version    : 12.2.0.1.44
  15. OUI version       : 12.2.0.7.0
  16. Log file location : /u01/app/oracle/product/19.3.0/db/cfgtoollogs/opatch/opatch2024-10-16_11-40-47AM_1.log
  17. Invoking prereq "checkconflictagainstohwithdetail"
  18. Prereq "checkConflictAgainstOHWithDetail" passed.
  19. OPatch succeeded.
复制代码
到这都没问题的话,就可以协商停机时间进行补丁升级了。
补丁升级

前置工作都做完之后,补丁升级步骤实在很简朴,RAC 滚动升级也可以使用这种方式:
  1. ## 关闭数据库
  2. [oracle@rhel8:/soft/36912597]$ sas
  3. SQL*Plus: Release 19.0.0.0.0 - Production on Wed Oct 16 11:41:14 2024
  4. Version 19.3.0.0.0
  5. Copyright (c) 1982, 2019, Oracle.  All rights reserved.
  6. Connected to:
  7. Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
  8. Version 19.3.0.0.0
  9. SYS@orclcdb SQL> shu immediate
  10. Database closed.
  11. Database dismounted.
  12. ORACLE instance shut down.
  13. SYS@orclcdb SQL>
  14. ## 关闭监听
  15. [oracle@rhel8:/soft/36912597]$ lsnrctl stop
  16. LSNRCTL for Linux: Version 19.0.0.0.0 - Production on 16-OCT-2024 11:42:13
  17. Copyright (c) 1991, 2019, Oracle.  All rights reserved.
  18. Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=rhel8)(PORT=1521)))
  19. The command completed successfully
  20. ## 静默安装补丁(确保没有 oracle 相关进程之后就可以安装补丁)
  21. [oracle@rhel8:/soft/36912597]$ opatch apply -silent
  22. Oracle Interim Patch Installer version 12.2.0.1.44
  23. Copyright (c) 2024, Oracle Corporation.  All rights reserved.
  24. Oracle Home       : /u01/app/oracle/product/19.3.0/db
  25. Central Inventory : /u01/app/oraInventory
  26.    from           : /u01/app/oracle/product/19.3.0/db/oraInst.loc
  27. OPatch version    : 12.2.0.1.44
  28. OUI version       : 12.2.0.7.0
  29. Log file location : /u01/app/oracle/product/19.3.0/db/cfgtoollogs/opatch/opatch2024-10-16_11-44-04AM_1.log
  30. Verifying environment and performing prerequisite checks...
  31. OPatch continues with these patches:   36912597  
  32. Do you want to proceed? [y|n]
  33. Y (auto-answered by -silent)
  34. User Responded with: Y
  35. All checks passed.
  36. Please shutdown Oracle instances running out of this ORACLE_HOME on the local system.
  37. (Oracle Home = '/u01/app/oracle/product/19.3.0/db')
  38. Is the local system ready for patching? [y|n]
  39. Y (auto-answered by -silent)
  40. User Responded with: Y
  41. Backing up files...
  42. Applying interim patch '36912597' to OH '/u01/app/oracle/product/19.3.0/db'
  43. ApplySession: Optional component(s) [ oracle.network.gsm, 19.0.0.0.0 ] , [ oracle.crypto.rsf, 19.0.0.0.0 ] , [ oracle.pg4appc, 19.0.0.0.0 ] , [ oracle.pg4mq, 19.0.0.0.0 ] , [ oracle.precomp.companion, 19.0.0.0.0 ] , [ oracle.rdbms.ic, 19.0.0.0.0 ] , [ oracle.rdbms.tg4db2, 19.0.0.0.0 ] , [ oracle.tfa, 19.0.0.0.0 ] , [ oracle.sdo.companion, 19.0.0.0.0 ] , [ oracle.net.cman, 19.0.0.0.0 ] , [ oracle.oid.client, 19.0.0.0.0 ] , [ oracle.xdk.companion, 19.0.0.0.0 ] , [ oracle.options.olap.api, 19.0.0.0.0 ] , [ oracle.ons.eons.bwcompat, 19.0.0.0.0 ] , [ oracle.rdbms.tg4msql, 19.0.0.0.0 ] , [ oracle.network.cman, 19.0.0.0.0 ] , [ oracle.rdbms.tg4tera, 19.0.0.0.0 ] , [ oracle.rdbms.tg4ifmx, 19.0.0.0.0 ] , [ oracle.rdbms.tg4sybs, 19.0.0.0.0 ] , [ oracle.ldap.ztk, 19.0.0.0.0 ] , [ oracle.ons.cclient, 19.0.0.0.0 ] , [ oracle.options.olap, 19.0.0.0.0 ] , [ oracle.jdk, 1.8.0.191.0 ] , [ oracle.jdk, 1.8.0.391.11 ]  not present in the Oracle Home or a higher version is found.
  44. Patching component oracle.rdbms, 19.0.0.0.0...
  45. Patching component oracle.rdbms.util, 19.0.0.0.0...
  46. Patching component oracle.rdbms.rsf, 19.0.0.0.0...
  47. Patching component oracle.assistants.acf, 19.0.0.0.0...
  48. Patching component oracle.assistants.deconfig, 19.0.0.0.0...
  49. Patching component oracle.assistants.server, 19.0.0.0.0...
  50. Patching component oracle.blaslapack, 19.0.0.0.0...
  51. Patching component oracle.buildtools.rsf, 19.0.0.0.0...
  52. Patching component oracle.ctx, 19.0.0.0.0...
  53. Patching component oracle.dbdev, 19.0.0.0.0...
  54. Patching component oracle.dbjava.ic, 19.0.0.0.0...
  55. Patching component oracle.dbjava.jdbc, 19.0.0.0.0...
  56. Patching component oracle.dbjava.ucp, 19.0.0.0.0...
  57. Patching component oracle.duma, 19.0.0.0.0...
  58. Patching component oracle.javavm.client, 19.0.0.0.0...
  59. Patching component oracle.ldap.owm, 19.0.0.0.0...
  60. Patching component oracle.ldap.rsf, 19.0.0.0.0...
  61. Patching component oracle.ldap.security.osdt, 19.0.0.0.0...
  62. Patching component oracle.marvel, 19.0.0.0.0...
  63. Patching component oracle.network.rsf, 19.0.0.0.0...
  64. Patching component oracle.odbc.ic, 19.0.0.0.0...
  65. Patching component oracle.ons, 19.0.0.0.0...
  66. Patching component oracle.ons.ic, 19.0.0.0.0...
  67. Patching component oracle.oracore.rsf, 19.0.0.0.0...
  68. Patching component oracle.perlint, 5.28.1.0.0...
  69. Patching component oracle.precomp.common.core, 19.0.0.0.0...
  70. Patching component oracle.precomp.rsf, 19.0.0.0.0...
  71. Patching component oracle.rdbms.crs, 19.0.0.0.0...
  72. Patching component oracle.rdbms.dbscripts, 19.0.0.0.0...
  73. Patching component oracle.rdbms.deconfig, 19.0.0.0.0...
  74. Patching component oracle.rdbms.oci, 19.0.0.0.0...
  75. Patching component oracle.rdbms.rsf.ic, 19.0.0.0.0...
  76. Patching component oracle.rdbms.scheduler, 19.0.0.0.0...
  77. Patching component oracle.rhp.db, 19.0.0.0.0...
  78. Patching component oracle.rsf, 19.0.0.0.0...
  79. Patching component oracle.sdo, 19.0.0.0.0...
  80. Patching component oracle.sdo.locator.jrf, 19.0.0.0.0...
  81. Patching component oracle.sqlplus, 19.0.0.0.0...
  82. Patching component oracle.sqlplus.ic, 19.0.0.0.0...
  83. Patching component oracle.wwg.plsql, 19.0.0.0.0...
  84. Patching component oracle.xdk.rsf, 19.0.0.0.0...
  85. Patching component oracle.javavm.server, 19.0.0.0.0...
  86. Patching component oracle.xdk.xquery, 19.0.0.0.0...
  87. Patching component oracle.ctx.rsf, 19.0.0.0.0...
  88. Patching component oracle.ovm, 19.0.0.0.0...
  89. Patching component oracle.oraolap, 19.0.0.0.0...
  90. Patching component oracle.nlsrtl.rsf.lbuilder, 19.0.0.0.0...
  91. Patching component oracle.rdbms.rat, 19.0.0.0.0...
  92. Patching component oracle.ldap.rsf.ic, 19.0.0.0.0...
  93. Patching component oracle.rdbms.dv, 19.0.0.0.0...
  94. Patching component oracle.xdk, 19.0.0.0.0...
  95. Patching component oracle.mgw.common, 19.0.0.0.0...
  96. Patching component oracle.ldap.client, 19.0.0.0.0...
  97. Patching component oracle.install.deinstalltool, 19.0.0.0.0...
  98. Patching component oracle.rdbms.rman, 19.0.0.0.0...
  99. Patching component oracle.oraolap.api, 19.0.0.0.0...
  100. Patching component oracle.dbtoolslistener, 19.0.0.0.0...
  101. Patching component oracle.rdbms.drdaas, 19.0.0.0.0...
  102. Patching component oracle.rdbms.hs_common, 19.0.0.0.0...
  103. Patching component oracle.rdbms.lbac, 19.0.0.0.0...
  104. Patching component oracle.sdo.locator, 19.0.0.0.0...
  105. Patching component oracle.rdbms.dm, 19.0.0.0.0...
  106. Patching component oracle.ldap.ssl, 19.0.0.0.0...
  107. Patching component oracle.xdk.parser.java, 19.0.0.0.0...
  108. Patching component oracle.odbc, 19.0.0.0.0...
  109. Patching component oracle.network.listener, 19.0.0.0.0...
  110. Patching component oracle.ctx.atg, 19.0.0.0.0...
  111. Patching component oracle.rdbms.install.common, 19.0.0.0.0...
  112. Patching component oracle.rdbms.hsodbc, 19.0.0.0.0...
  113. Patching component oracle.network.aso, 19.0.0.0.0...
  114. Patching component oracle.rdbms.locator, 19.0.0.0.0...
  115. Patching component oracle.rdbms.install.plugins, 19.0.0.0.0...
  116. Patching component oracle.nlsrtl.rsf, 19.0.0.0.0...
  117. Patching component oracle.nlsrtl.rsf.core, 19.0.0.0.0...
  118. Patching component oracle.nlsrtl.rsf.ic, 19.0.0.0.0...
  119. Patching component oracle.oraolap.dbscripts, 19.0.0.0.0...
  120. Patching component oracle.network.client, 19.0.0.0.0...
  121. Patching component oracle.precomp.common, 19.0.0.0.0...
  122. Patching component oracle.precomp.lang, 19.0.0.0.0...
  123. Patching component oracle.jdk, 1.8.0.201.0...
  124. Patch 36912597 successfully applied.
  125. Sub-set patch [29517242] has become inactive due to the application of a super-set patch [36912597].
  126. Please refer to Doc ID 2161861.1 for any possible further required actions.
  127. Log file location: /u01/app/oracle/product/19.3.0/db/cfgtoollogs/opatch/opatch2024-10-16_11-44-04AM_1.log
  128. OPatch succeeded.
复制代码
19.25 RU 补丁安装比较慢,要耐心等待,这里安装完最后还有一个提示(这个是正常的提示,可以忽略):
  1. Sub-set patch [29517242] has become inactive due to the application of a super-set patch [36912597].
  2. Please refer to Doc ID 2161861.1 for any possible further required actions.
复制代码
这个 29517242 补丁就是我们安装好 19C 数据库之后默认安装的补丁版本:
  1. 29517242;Database Release Update : 19.3.0.0.190416 (29517242)
复制代码
通过查看相关文档可以发现:
  1. For information about Release Updates please read Note:2285040.1 .
  2. The new RUs will be a superset of a previous RU patches.
  3. ## Note:2285040.1 About list
  4. It is possible to move back and forth from Updates to Revisions*. However, there are some restrictions as the new patch level must be a super set of the previous. To avoid surprises with patch conflicts, customers should aim to stick to a consistent policy of always taking the same Revision level (i.e. Release.Update.0, Release.Update.1 or Release.Update.2) for their quarterly maintenance cycles.
复制代码
软件补丁安装完成后,对数据库也要执行 datapatch,须要先打开数据库:
  1. [oracle@rhel8:/soft/36912597]$ sas
  2. SQL*Plus: Release 19.0.0.0.0 - Production on Wed Oct 16 12:11:41 2024
  3. Version 19.25.0.0.0
  4. Copyright (c) 1982, 2024, Oracle.  All rights reserved.
  5. Connected to an idle instance.
  6. ## 打开数据库
  7. SYS@orclcdb SQL> startup
  8. ORACLE instance started.
  9. Total System Global Area 5318374376 bytes
  10. Fixed Size                  9192424 bytes
  11. Variable Size             922746880 bytes
  12. Database Buffers         4378853376 bytes
  13. Redo Buffers                7581696 bytes
  14. Database mounted.
  15. Database opened.
  16. SYS@orclcdb SQL> show pdbs
  17.     CON_ID CON_NAME                       OPEN MODE  RESTRICTED
  18. ---------- ------------------------------ ---------- ----------
  19.          2 PDB$SEED                       READ ONLY  NO
  20.          3 TESTPDB                        READ WRITE NO
  21. ## 这里是 CDB 架构,所以需要打开 PDB(如果配置了 PDB 随 CDB 自启,则跳过这一步,安装脚本默认配置了)
  22. SQL> alter pluggable database all open;
  23. SYS@orclcdb SQL> exit;
  24. Disconnected from Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
  25. Version 19.25.0.0.0
复制代码
执行 datapatch:
  1. ## 这一步是可选的,执行后会运行一系列环境和数据库检查,确保 datapatch 能够安装成功
  2. [oracle@rhel8:/home/oracle]$ datapatch -sanity_checks
  3. ## 执行 datapatch
  4. [oracle@rhel8:/home/oracle]$ datapatch -verbose
  5. SQL Patching tool version 19.25.0.0.0 Production on Wed Oct 16 12:15:01 2024
  6. Copyright (c) 2012, 2024, Oracle.  All rights reserved.
  7. Log file for this invocation: /u01/app/oracle/cfgtoollogs/sqlpatch/sqlpatch_7263_2024_10_16_12_15_01/sqlpatch_invocation.log
  8. Connecting to database...OK
  9. Gathering database info...done
  10. Note:  Datapatch will only apply or rollback SQL fixes for PDBs
  11.        that are in an open state, no patches will be applied to closed PDBs.
  12.        Please refer to Note: Datapatch: Database 12c Post Patch SQL Automation
  13.        (Doc ID 1585822.1)
  14. Bootstrapping registry and package to current versions...done
  15. Determining current state...done
  16. Current state of interim SQL patches:
  17.   No interim patches found
  18. Current state of release update SQL patches:
  19.   Binary registry:
  20.     19.25.0.0.0 Release_Update 241010184253: Installed
  21.   PDB CDB$ROOT:
  22.     Applied 19.3.0.0.0 Release_Update 190410122720 successfully on 16-OCT-24 11.22.47.880070 AM
  23.   PDB PDB$SEED:
  24.     Applied 19.3.0.0.0 Release_Update 190410122720 successfully on 16-OCT-24 11.31.48.661607 AM
  25.   PDB TESTPDB:
  26.     Applied 19.3.0.0.0 Release_Update 190410122720 successfully on 16-OCT-24 11.31.48.661607 AM
  27. Adding patches to installation queue and performing prereq checks...done
  28. Installation queue:
  29.   For the following PDBs: CDB$ROOT PDB$SEED TESTPDB
  30.     No interim patches need to be rolled back
  31.     Patch 36912597 (Database Release Update : 19.25.0.0.241015 (36912597)):
  32.       Apply from 19.3.0.0.0 Release_Update 190410122720 to 19.25.0.0.0 Release_Update 241010184253
  33.     No interim patches need to be applied
  34. Installing patches...
  35. Patch installation complete.  Total patches installed: 3
  36. Validating logfiles...done
  37. Patch 36912597 apply (pdb CDB$ROOT): SUCCESS
  38.   logfile: /u01/app/oracle/cfgtoollogs/sqlpatch/36912597/25871884/36912597_apply_ORCLCDB_CDBROOT_2024Oct16_12_17_39.log (no errors)
  39. Patch 36912597 apply (pdb PDB$SEED): SUCCESS
  40.   logfile: /u01/app/oracle/cfgtoollogs/sqlpatch/36912597/25871884/36912597_apply_ORCLCDB_PDBSEED_2024Oct16_12_29_25.log (no errors)
  41. Patch 36912597 apply (pdb TESTPDB): SUCCESS
  42.   logfile: /u01/app/oracle/cfgtoollogs/sqlpatch/36912597/25871884/36912597_apply_ORCLCDB_TESTPDB_2024Oct16_12_29_25.log (no errors)
  43. Automatic recompilation incomplete; run utlrp.sql to revalidate.
  44.   PDBs: PDB$SEED TESTPDB
  45. SQL Patching tool complete on Wed Oct 16 12:38:40 2024
复制代码
查看补丁版本:
  1. [oracle@rhel8:/home/oracle]$ sqlplus -v
  2. SQL*Plus: Release 19.0.0.0.0 - Production
  3. Version 19.25.0.0.0
  4. [oracle@rhel8:/home/oracle]$ opatch lspatches
  5. 36912597;Database Release Update : 19.25.0.0.241015 (36912597)
  6. 29585399;OCW RELEASE UPDATE 19.3.0.0.0 (29585399)
  7. OPatch succeeded.
复制代码
至此,数据库 19.25 补丁安装完成。
一键安装补丁

如果你是新安装一套数据库,须要安装最新补丁 19.25,使用 Oracle 一键安装脚本可以轻松完成。
   脚本下载:Oracle一键安装脚本
作者微信:Lucifer-0622
  《❓关于Oracle一键安装脚本的 21 个疑问与解答》
Oracle 一键安装脚本实操合集,持续更新中!!!
这里演示一下 19C 一键安装,同时安装 DB 和 OJVM 补丁的命令:
  1. # 提前上传好安装包和安装脚本即可
  2. [root@KeyarchOS soft]# ll
  3. -rwx------ 1 root root 3059705302 10月 16 10:35 LINUX.X64_193000_db_home.zip
  4. -rwxr-xr-x 1 root root     243175 10月 16 10:33 OracleShellInstall
  5. -rwxr-xr-x 1 root root  127601834 10月 16 10:29 p36878697_190000_Linux-x86-64.zip
  6. -rwxr-xr-x 1 root root 1776391552 10月 16 10:28 p36912597_190000_Linux-x86-64.zip
  7. -rwxr-xr-x 1 root root  134583311 10月 16 10:27 p6880880_190000_Linux-x86-64.zip
  8. # 执行一键安装命令
  9. ./OracleShellInstall -lf ens33 `# local ip ifname`\
  10. -n KeyarchOS `# hostname`\
  11. -op oracle `# oracle password`\
  12. -d /u01 `# software base dir`\
  13. -ord /oradata `# data dir`\
  14. -o orclcdb `# dbname`\
  15. -pdb lucifer `# pdbname`\
  16. -dp oracle `# sys/system password`\
  17. -ds AL32UTF8 `# database character`\
  18. -ns AL16UTF16 `# national character`\
  19. -redo 100 `# redo size`\
  20. -opa 36912597 `# oracle PSU/RU`\
  21. -jpa 36878697 `# OJVM PSU/RU`\
  22. -opd Y `# optimize db`
复制代码
安装过程如下:
  1.    ███████                             ██          ████████ ██               ██  ██ ██                    ██              ██  ██
  2.   ██░░░░░██                           ░██         ██░░░░░░ ░██              ░██ ░██░██                   ░██             ░██ ░██
  3. ██     ░░██ ██████  ██████    █████  ░██  █████ ░██       ░██       █████  ░██ ░██░██ ███████   ██████ ██████  ██████   ░██ ░██
  4. ░██      ░██░░██░░█ ░░░░░░██  ██░░░██ ░██ ██░░░██░█████████░██████  ██░░░██ ░██ ░██░██░░██░░░██ ██░░░░ ░░░██░  ░░░░░░██  ░██ ░██
  5. ░██      ░██ ░██ ░   ███████ ░██  ░░  ░██░███████░░░░░░░░██░██░░░██░███████ ░██ ░██░██ ░██  ░██░░█████   ░██    ███████  ░██ ░██
  6. ░░██     ██  ░██    ██░░░░██ ░██   ██ ░██░██░░░░        ░██░██  ░██░██░░░░  ░██ ░██░██ ░██  ░██ ░░░░░██  ░██   ██░░░░██  ░██ ░██
  7. ░░███████  ░███   ░░████████░░█████  ███░░██████ ████████ ░██  ░██░░██████ ███ ███░██ ███  ░██ ██████   ░░██ ░░████████ ███ ███
  8.   ░░░░░░░   ░░░     ░░░░░░░░  ░░░░░  ░░░  ░░░░░░ ░░░░░░░░  ░░   ░░  ░░░░░░ ░░░ ░░░ ░░ ░░░   ░░ ░░░░░░     ░░   ░░░░░░░░ ░░░ ░░░
  9. 注意:本脚本仅用于新服务器上实施部署数据库使用,严禁在已运行数据库的主机上执行,以免发生数据丢失或者损坏,造成不可挽回的损失!!!                                                                                 
  10. 请选择安装模式 [单机(si)/单机ASM(sa)/集群(rac)] : si
  11. 数据库安装模式: single                                                                           
  12. 请选择数据库版本 [11|12|19|21|23] : 19
  13. 数据库版本:     19                                                                              
  14. !!! 免责声明:当前操作系统版本是 [ kos 5.8sp2 ] 不在 Oracle 官方支持列表,本脚本只负责安装,请确认是否继续安装 (Y/N): [Y]
  15. OracleShellInstall 开始安装,详细安装过程可查看日志: tail -2000f /soft/print_shell_install_20241016103558.log                                                                                 
  16. 正在进行安装前检查,请稍等......                                                                                 
  17. 正在检测安装包 /soft/LINUX.X64_193000_db_home.zip 的 MD5 值是否正确,请稍等......                                                                                 
  18. 正在配置本地软件源......已完成 (耗时: 1 秒)
  19. 正在获取操作系统信息......已完成 (耗时: 1 秒)
  20. 正在安装依赖包......已完成 (耗时: 95 秒)
  21. 正在禁用防火墙......已完成 (耗时: 1 秒)
  22. 正在禁用 selinux......已完成 (耗时: 1 秒)
  23. 正在配置 nsyctl......已完成 (耗时: 1 秒)
  24. 正在配置主机名和 hosts 文件......已完成 (耗时: 0 秒)
  25. 正在创建用户和组......已完成 (耗时: 2 秒)
  26. 正在创建安装目录......已完成 (耗时: 0 秒)
  27. 正在配置 Avahi-daemon 服务......已完成 (耗时: 1 秒)
  28. 正在配置透明大页 && NUMA && 磁盘 IO 调度器......已完成 (耗时: 2 秒)
  29. 正在配置操作系统参数 sysctl......已完成 (耗时: 1 秒)
  30. 正在配置 RemoveIPC......已完成 (耗时: 1 秒)
  31. 正在配置用户限制 limit......已完成 (耗时: 1 秒)
  32. 正在配置 shm 目录......已完成 (耗时: 0 秒)
  33. 正在安装 rlwrap 插件......已完成 (耗时: 11 秒)
  34. 正在配置用户环境变量......已完成 (耗时: 1 秒)
  35. 正在解压 Oracle 安装包以及补丁......已完成 (耗时: 172 秒)
  36. 正在安装 Oracle 软件以及补丁......已完成 (耗时: 1591 秒)
  37. 正在创建监听......已完成 (耗时: 5 秒)
  38. 正在创建数据库......已完成 (耗时: 2792 秒)
  39. 正在优化数据库......已完成 (耗时: 36 秒)
  40. 恭喜!Oracle 一键安装执行完成 (耗时: 4722 秒),现在是否重启主机:[Y/N] Y
  41. 正在重启当前节点主机......
复制代码
打补丁 + CDB 架构安装还是比较慢的,查看安装后的版本信息:
  1. [oracle@KeyarchOS:/home/oracle]$ sqlplus -v
  2. SQL*Plus: Release 19.0.0.0.0 - Production
  3. Version 19.25.0.0.0
  4. [oracle@KeyarchOS:/home/oracle]$ opatch lspatches
  5. 36878697;OJVM RELEASE UPDATE: 19.25.0.0.241015 (36878697)
  6. 36912597;Database Release Update : 19.25.0.0.241015 (36912597)
  7. 29585399;OCW RELEASE UPDATE 19.3.0.0.0 (29585399)
  8. OPatch succeeded.
复制代码
可以看到数据库补丁以及 OJVM 补丁均已乐成安装,数据库内部也可以查看补丁安装记录:
  1. set line2222 pages1000 tab off
  2. col comments for a80
  3. col version for a30
  4. col action for a20
  5. SELECT con_id,
  6.        comments,
  7.        version,
  8.        action,
  9.        action_time
  10.   FROM cdb_registry_history
  11. ORDER BY con_id;
  12.     CON_ID COMMENTS                                                                         VERSION                        ACTION               ACTION_TIME
  13. ---------- -------------------------------------------------------------------------------- ------------------------------ -------------------- ---------------------------------------------------------------------------
  14.          1 RDBMS_19.25.0.0.0DBRU_LINUX.X64_241010                                           19                             BOOTSTRAP
  15.          1 Patch applied from 19.3.0.0.0 to 19.25.0.0.0: Release_Update - 241010184253      19.0.0.0.0                     RU_APPLY             16-OCT-24 11.30.41.374179 AM
  16.          1 OJVM RU post-install                                                             19.25.0.0.241015OJVMRU         APPLY                16-OCT-24 11.15.56.916741 AM
  17.          1 RAN jvmpsu.sql                                                                   19.25.0.0.241015OJVMRU         jvmpsu.sql           16-OCT-24 11.15.56.806485 AM
  18.          3 RDBMS_19.25.0.0.0DBRU_LINUX.X64_241010                                           19                             BOOTSTRAP
  19.          3 Patch applied from 19.3.0.0.0 to 19.25.0.0.0: Release_Update - 241010184253      19.0.0.0.0                     RU_APPLY             16-OCT-24 11.48.46.775597 AM
  20.          3 OJVM RU post-install                                                             19.25.0.0.241015OJVMRU         APPLY                16-OCT-24 11.38.03.969056 AM
  21.          3 RAN jvmpsu.sql                                                                   19.25.0.0.241015OJVMRU         jvmpsu.sql           16-OCT-24 11.38.03.943917 AM
复制代码
至此,Oracle 一键安装演示结束。
写在最后

Oracle 数据库补丁安装实在并不难,官方提供的 README 已经一目了然,如果大家都可以耐心好好读一读,相信一定会受益匪浅。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

种地

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表