Oracle故障案例之-19C时区补丁DSTV38更新

📢📢📢📣📣📣
哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10余年DBA工作经验
一位上进心十足的【大数据领域博主】!😜😜😜
中国DBA联盟(ACDU)成员,目前从事DBA及程序编程
擅长Oracle、MySQL、PG 运维开发,备份恢复,安装迁移,性能优化、故障应急处理等。
✨ 如果有对【数据库】感兴趣的【小可爱】,欢迎关注【IT邦德】💞💞💞
❤️❤️❤️感谢各位大可爱小可爱!❤️❤️❤️

文章目录

  • 前言
    • 📣 1.故障案例
    • 📣 2.补丁下载
    • 📣 3.升级Opatch版本
    • 📣 4.检查Patch 是否冲突
    • 📣 5.应用补丁34006614
    • 📣 6.确认升级
    • 📣 7.升级TZ
      • ✨ 7.1 Upgrade mode下启动数据库
      • ✨ 7.2 升级前准备
      • ✨ 7.3 查找受影响的表
      • ✨ 7.4 开始升级TZ
      • ✨ 7.5 关闭升级模式
    • 📣 8.查看升级结果

前言

Oracle19C通过dump方式从TSTZ version 38 导入到低版本TSTZ version 32时报ORA-39405,本博客做了详细的处理过程说明。

📣 1.故障案例

ORA-39405: Oracle Data Pump does not support importing from a source database with TSTZ version 38 into a target database with TSTZ version 32.

在这里插入图片描述

--目标库
SQL> SELECT * FROM v$timezone_file;
FILENAME                VERSION     CON_ID
-------------------- ---------- ----------
timezlrg_32.dat              32          0

--源库
SQL> SELECT * FROM v$timezone_file;
FILENAME                VERSION     CON_ID
-------------------- ---------- ----------
timezlrg_38.dat              38          0

SELECT DBMS_DST.get_latest_timezone_version FROM dual;

综合以上报错及官方的案例,特对本次故障进行如下的处理,需要对原库进行补丁的升级

📣 2.补丁下载

下载最新的 OPatch 和 DSTV38 更新补丁

Opatch Version Patch:
https://updates.oracle.com/download/6880880.html

在这里插入图片描述

DST V38 Patch:
https://updates.oracle.com/download/34006614.html

在这里插入图片描述

📣 3.升级Opatch版本

[root@dbhost ~]# cd /opt
[root@dbhost opt]# chown oracle:oinstall -R p6880880_190000_Linux-x86-64.zip
[root@dbhost opt]# chmod 755 -R p6880880_190000_Linux-x86-64.zip

--备份原来的OPatch
[root@dbhost ~]# su - oracle
Last login: Sun Aug 20 13:09:38 CST 2023 on pts/0
[oracle@dbhost ~]$ cd $ORACLE_HOME/
[oracle@dbhost dbhome_1]$ mv OPatch OPatch_bak

--应用新的补丁
unzip /opt/p6880880_190000_Linux-x86-64.zip -d $ORACLE_HOME
[oracle@dbhost ~]$ cd $ORACLE_HOME/OPatch
[oracle@dbhost OPatch]$ ./opatch version
OPatch Version: 12.2.0.1.28
OPatch succeeded.

📣 4.检查Patch 是否冲突

[root@dbhost opt]# chown oracle:oinstall -R p34006614_190000_Linux-x86-64.zip
[root@dbhost opt]# chmod 755 -R p34006614_190000_Linux-x86-64.zip

[oracle@dbhost ~]$ unzip /opt/p34006614_190000_Linux-x86-64.zip -d /opt
[oracle@dbhost ~]$ $ORACLE_HOME/OPatch/opatch prereq CheckConflictAgainstOHWithDetail -ph /opt/34006614

在这里插入图片描述

📣 5.应用补丁34006614

[oracle@dbhost ~]$ cd /opt/34006614/
[oracle@dbhost 34006614]$ $ORACLE_HOME/OPatch/opatch apply -oh $ORACLE_HOME

Oracle Interim Patch Installer version 12.2.0.1.28
Copyright (c) 2023, Oracle Corporation.  All rights reserved.


Oracle Home       : /u01/app/oracle/product/19.3.0/dbhome_1
Central Inventory : /u01/app/oraInventory
   from           : /u01/app/oracle/product/19.3.0/dbhome_1/oraInst.loc
OPatch version    : 12.2.0.1.28
OUI version       : 12.2.0.7.0
Log file location : /u01/app/oracle/product/19.3.0/dbhome_1/cfgtoollogs/opatch/opatch2023-08-20_14-02-53PM_1.log

Verifying environment and performing prerequisite checks...
OPatch continues with these patches:   34006614  

Do you want to proceed? [y|n]
y
User Responded with: Y
All checks passed.
Backing up files...
Applying interim patch '34006614' to OH '/u01/app/oracle/product/19.3.0/dbhome_1'

Patching component oracle.oracore.rsf, 19.0.0.0.0...
Patch 34006614 successfully applied.
Log file location: /u01/app/oracle/product/19.3.0/dbhome_1/cfgtoollogs/opatch/opatch2023-08-20_14-02-53PM_1.log

OPatch succeeded.

📣 6.确认升级

[oracle@dbhost ~]$ $ORACLE_HOME/OPatch/opatch lsinv | grep -i “DSTV38 UPDATE”
Patch description: “RDBMS - DSTV38 UPDATE - TZDATA2022A”

--查看当前 TZ 版本
SQL> SELECT * FROM v$timezone_file;

FILENAME                VERSION     CON_ID
-------------------- ---------- ----------
timezlrg_32.dat              32          0

SQL> col PROPERTY_NAME for a30
SQL> set line 200           
SQL> SELECT PROPERTY_NAME, SUBSTR(property_value, 1, 30) value 
FROM DATABASE_PROPERTIES 
WHERE PROPERTY_NAME LIKE 'DST_%' ORDER BY PROPERTY_NAME;

PROPERTY_NAME                  VALUE
------------------------------ ----------------------------
DST_PRIMARY_TT_VERSION         32
DST_SECONDARY_TT_VERSION       0
DST_UPGRADE_STATE              NONE

--查看下载的TZ版本
SQL> SELECT DBMS_DST.get_latest_timezone_version FROM dual;

GET_LATEST_TIMEZONE_VERSION
---------------------------
                         38

[oracle@dbhost ~]$ cd $ORACLE_HOME/oracore/zoneinfo
[oracle@dbhost zoneinfo]$ ls
big              timezlrg_17.dat  timezlrg_28.dat  timezlrg_8.dat   timezone_1.dat   timezone_30.dat
little           timezlrg_18.dat  timezlrg_29.dat  timezlrg_9.dat   timezone_20.dat  timezone_31.dat
readme_38.txt    timezlrg_19.dat  timezlrg_2.dat   timezone_10.dat  timezone_21.dat  timezone_32.dat
readme.txt       timezlrg_1.dat   timezlrg_30.dat  timezone_11.dat  timezone_22.dat  timezone_38.dat
timezdif.csv     timezlrg_20.dat  timezlrg_31.dat  timezone_12.dat  timezone_23.dat  timezone_3.dat
timezlrg_10.dat  timezlrg_21.dat  timezlrg_32.dat  timezone_13.dat  timezone_24.dat  timezone_4.dat
timezlrg_11.dat  timezlrg_22.dat  timezlrg_38.dat  timezone_14.dat  timezone_25.dat  timezone_5.dat
timezlrg_12.dat  timezlrg_23.dat  timezlrg_3.dat   timezone_15.dat  timezone_26.dat  timezone_6.dat
timezlrg_13.dat  timezlrg_24.dat  timezlrg_4.dat   timezone_16.dat  timezone_27.dat  timezone_7.dat
timezlrg_14.dat  timezlrg_25.dat  timezlrg_5.dat   timezone_17.dat  timezone_28.dat  timezone_8.dat
timezlrg_15.dat  timezlrg_26.dat  timezlrg_6.dat   timezone_18.dat  timezone_29.dat  timezone_9.dat
timezlrg_16.dat  timezlrg_27.dat  timezlrg_7.dat   timezone_19.dat  timezone_2.dat

📣 7.升级TZ

注意:先关闭数据库和监听哈
[oracle@dbhost ~]$ lsnrctl stop
[oracle@dbhost ~]$ sqlplus / as sysdba
SQL> shutdown immediate

✨ 7.1 Upgrade mode下启动数据库

SQL> STARTUP UPGRADE;

SQL> select name, open_mode from v$database;
NAME      OPEN_MODE
--------- --------------------
ORCL      READ WRITE
SQL> select instance_name, status from v$instance;
INSTANCE_NAME    STATUS
---------------- ------------
orcl             OPEN MIGRATE

✨ 7.2 升级前准备

SQL> DECLARE
l_tz_version PLS_INTEGER;
BEGIN
l_tz_version := DBMS_DST.get_latest_timezone_version;
DBMS_OUTPUT.put_line(‘l_tz_version=’ || l_tz_version);
DBMS_DST.begin_prepare(l_tz_version);
END;
/

SQL> COLUMN property_name FORMAT A30

SELECT property_name, property_value
FROM   database_properties
WHERE  property_name LIKE 'DST_%'
ORDER BY property_name;

PROPERTY_NAME                  PROPERTY_VALUE
------------------------------ --------------------
DST_PRIMARY_TT_VERSION         32
DST_SECONDARY_TT_VERSION       38
DST_UPGRADE_STATE              PREPARE

✨ 7.3 查找受影响的表

SQL> EXEC DBMS_DST.find_affected_tables;

PL/SQL procedure successfully completed.

SQL> select count(*) from sys.dst$affected_tables;

  COUNT(*)
----------
         0
结束升级前准备
SQL> EXEC DBMS_DST.end_prepare;
PL/SQL procedure successfully completed.

✨ 7.4 开始升级TZ

SQL> shutdown immediate;
SQL> startup upgrade;

SQL> SET SERVEROUTPUT ON
DECLARE
  l_tz_version PLS_INTEGER;
BEGIN
  SELECT DBMS_DST.get_latest_timezone_version
  INTO   l_tz_version
  FROM   dual;

  DBMS_OUTPUT.put_line('l_tz_version=' || l_tz_version);
  DBMS_DST.begin_upgrade(l_tz_version);
END;
/

在这里插入图片描述

✨ 7.5 关闭升级模式

SQL> shut immediate;
SQL> startup;

SQL> SET SERVEROUTPUT ON

DECLARE
  l_failures   PLS_INTEGER;
BEGIN
  DBMS_DST.upgrade_database(l_failures);
  DBMS_OUTPUT.put_line('DBMS_DST.upgrade_database : l_failures=' || l_failures);
  DBMS_DST.end_upgrade(l_failures);
  DBMS_OUTPUT.put_line('DBMS_DST.end_upgrade : l_failures=' || l_failures);
END;
/

在这里插入图片描述

📣 8.查看升级结果

SQL> SELECT property_name, property_value
FROM database_properties
WHERE property_name LIKE ‘DST_%’
ORDER BY property_name;

PROPERTY_NAME                  PROPERTY_VALUE
------------------------------ --------------------
DST_PRIMARY_TT_VERSION         38
DST_SECONDARY_TT_VERSION       0
DST_UPGRADE_STATE              NONE


[oracle@dbhost ~]$ cd $ORACLE_HOME/OPatch
[oracle@dbhost OPatch]$ ./opatch lspatches
34006614;RDBMS - DSTV38 UPDATE - TZDATA2022A
29585399;OCW RELEASE UPDATE 19.3.0.0.0 (29585399)
29517242;Database Release Update : 19.3.0.0.190416 (29517242)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/82155.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

《TCP IP网络编程》第二十四章

第 24 章 制作 HTTP 服务器端 24.1 HTTP 概要 本章将编写 HTTP(HyperText Transfer Protocol,超文本传输协议)服务器端,即 Web 服务器端。 理解 Web 服务器端: web服务器端就是要基于 HTTP 协议,将网页对…

2023国赛数学建模E题思路模型代码 高教社杯

本次比赛我们将会全程更新思路模型及代码,大家查看文末名片获取 之前国赛相关的资料和助攻可以查看 2022数学建模国赛C题思路分析_2022国赛c题matlab_UST数模社_的博客-CSDN博客 2022国赛数学建模A题B题C题D题资料思路汇总 高教社杯_2022国赛c题matlab_UST数模社…

RK3588平台开发系列讲解(AI 篇)RKNN-Toolkit2 API 介绍

文章目录 一、RKNN 初始化及对象释放二、RKNN 模型配置沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇章主要讲解 RKNN-Toolkit2 API 详细说明。 一、RKNN 初始化及对象释放 在使用 RKNN Toolkit2 的所有 API 接口时,都需要先调用 RKNN()方法初始化 RKNN 对象,…

图数据库_Neo4j和SpringBoot整合使用_实战创建明星关系图谱---Neo4j图数据库工作笔记0010

然后我们再来看一下这个明星关系图谱 可以看到这里 这个是原来的startRelation 我们可以写CQL去查询对应的关系 可以看到,首先查询出来以后,然后就可以去创建 我们可以把写的创建明星关系的CQL,拿到 springboot中去执行 可以看到,这里我们先写一个StarRelationRepository,然…

工作6年了日期时间格式化还在写YYYY疯狂给队友埋雷

前言 哈喽小伙伴们好久不见,今天来个有意思的雷,看你有没有埋过。 正文 不多说废话,公司最近来了个外地回来的小伙伴,在广州工作过6年,也是一名挺有经验的开发。 他提交的代码被小组长发现有问题,给打回了&…

【C语言练习】数组OJ题

目录 一.消失的数字思路1:思路2: 二.移除元素三.轮转数组四.删除有序数组中的重复项五.合并两个有序数组 一.消失的数字 题目: 思路1: 数组是从0加到N,所以把0到N的数加起来减去数组中的值,结果就是消失…

文心一言最新重磅发布!

8月16日,由深度学习技术及应用国家工程研究中心主办的WAVE SUMMIT深度学习开发者大会2023举办。百度首席技术官、深度学习技术及应用国家工程研究中心主任王海峰以《大语言模型为通用人工智能带来曙光》为题,阐述了大语言模型具备理解、生成、逻辑、记忆…

【学习日记】【FreeRTOS】时间片的实现

前言 本文以野火的教程和代码为基础,对 FreeRTOS 中时间片的概念作了解释,并且给出了实现方式,同时发现并解决了野火教程代码中的 bug。 一、时间片是什么 在前面的文章中,我们已经知道任务根据不同的优先级被放入就绪列表中不…

Linux 安全技术和防火墙

目录 1 安全技术 2 防火墙 2.1 防火墙的分类 2.1.1 包过滤防火墙 2.1.2 应用层防火墙 3 Linux 防火墙的基本认识 3.1 iptables & netfilter 3.2 四表五链 4 iptables 4.2 数据包的常见控制类型 4.3 实际操作 4.3.1 加新的防火墙规则 4.3.2 查看规则表 4.3.…

Qt实现简单的漫游器

文章目录 Qt的OpenGL窗口GLSL的实现摄像机类的实现简单的漫游器 Qt的OpenGL窗口 Qt主要是使用QOpenGLWidget来实现opengl的功能。  QOpenGLWidget 提供了三个便捷的虚函数,可以重载,用来重新实现典型的OpenGL任务: paintGL:渲染…

BDA初级分析——SQL多表连接应用

一、用SQL拼接数据 三个初始数据 问题1:在所有的数据里,销售额最高的产品品类名是什么? 问题2:是否有什么产品是在所观测的时间里没有被购买过的? 拼接数据:JOIN join,加入 作用&#xff1…

【NEW】视频云存储EasyCVR平台H.265转码配置增加分辨率设置

关于视频分析EasyCVR视频汇聚平台的转码功能,我们在此前的文章中也介绍过不少,感兴趣的用户可以翻阅往期的文章进行了解。 安防视频集中存储EasyCVR视频监控综合管理平台可以根据不同的场景需求,让平台在内网、专网、VPN、广域网、互联网等各…

【前端|JS实战第1篇】使用JS来实现属于自己的贪吃蛇游戏!

前言 贪吃蛇游戏是经典的小游戏,也是学习前端JS的一个很好的练习项目。在本教程中,我们将使用 JavaScript 来逐步构建一个贪吃蛇游戏。我们会从创建游戏区域开始,逐步添加蛇的移动、食物的生成以及游戏逻辑等功能。 🚀 作者简介&a…

【Lua】(一)VSCode 搭建 Lua 开发环境

前言 最近在找工作,基本所有的岗位都会问到 Lua(甚至拼 UI 的都要求会 Lua),咱能怎么办呢,咱也只能学啊…… 工欲善其事,必先利其器。第一步,先来把环境配置好吧! 当前适用版本&a…

【C语言】使用C语言,实现九九乘法表(另附Python、Java、JavaScript实现方式)

文章目录 1. C语言实现1.1 思路1.2 代码实现 3.其他语言实现3.1 Python实现3.2 Java实现3.3 JavaScript实现 1. C语言实现 1.1 思路 九九乘法表图示: 思路如下:定义两层for循环即可实现九九乘法表 一共有9层,所以要定义一个变量i&#xff…

Git概述

目录 一、什么是Git 二、什么是版本控制系统 三、Git和SVN对比 SVN集中式 SVN优缺点 Git分布式 Git优缺点 四、Git工作流程 四个工作区域 工作流程 五、Git下载与安装 一、什么是Git 很多人都知道,林纳斯托瓦兹在1991年创建了开源的Linux,从…

uniapp编写微信小程序和H5遇到的坑总结

uniapp编写微信小程序和H5遇到的坑总结 1、阻止事件冒泡2、二维码生成3、H5跨域配置4、H5时,地址栏上添加版本号5、H5时,tabBar遮挡部分内容6、uniapp使用webview通信6.1、uniapp编写的小程序嵌入h5之间的通信6.1.1、小程序向h5发送消息6.1.2、h5向小程序…

BDA初级分析——SQL清洗和整理数据

一、数据处理 数据处理之类型转换 字符格式与数值格式存储的数据,同样是进行大小排序, 会有什么区别? 以rev为例,看看字符格式与数值格式存储时,排序会有什么区别? 用cast as转换为字符后进行排序 SEL…

广东灯具3D扫描抄数建模服务3D测绘出图纸三维逆向设计-CASAIM

灯具三维逆向建模是一种将实际物体转换为数字模型的过程。通过逆向工程技术,可以将现有的灯具进行3D扫描,然后利用专业的逆向设计软件将其转换为准确的三维模型。 以下是CASAIM实施灯具三维逆向建模的一般步骤图: 1. 扫描:三维扫…

Linux 系统编程拾遗

Linux 系统编程拾遗 进程的创建 进程的创建 fork()、exit()、wait()以及execve()的简介 创建新进程:fork()
最新文章