当前位置: 首页 > news >正文

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          0SELECT 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/oraInventoryfrom           : /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.logVerifying 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.logOPatch 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          0SQL> 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 A30SELECT 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
DECLAREl_tz_version PLS_INTEGER;
BEGINSELECT DBMS_DST.get_latest_timezone_versionINTO   l_tz_versionFROM   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 ONDECLAREl_failures   PLS_INTEGER;
BEGINDBMS_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.lryc.cn/news/132278.html

相关文章:

  • 设计模式之组合模式(Composite)的C++实现
  • mongo的include方法踩坑
  • 阿里云无影云电脑/云桌面收费价格表_使用申请方法
  • jvm内存溢出排查(使用idea自带的内存泄漏分析工具)
  • JS内存泄漏
  • 线程和进程同步互斥你真的掌握了吗?(同步互斥机制保姆级讲解与应用)
  • Android 9.0 Vold挂载流程解析(上)
  • 界面组件Telerik UI for WinForms R2 2023——拥有VS2022暗黑主题
  • vue+elementui 实现文本超出长度显示省略号,鼠标移上悬浮展示全部内容
  • 【STM32RT-Thread零基础入门】 5. 线程创建应用(线程创建、删除、初始化、脱离、启动、睡眠)
  • 计算机竞赛 python+深度学习+opencv实现植物识别算法系统
  • 深度探索ChatGPT:如何进行专业提问以获取精确答案
  • 1.vue3+vite开发中axios使用及跨域问题解决
  • 【LangChain】P1 LangChain 应用程序的核心构建模块 LLMChain 以及其三大部分
  • 关于查看处理端口号和进程[linux]
  • C 语言的 strcat() 函数和 strncat() 函数
  • C++ string 的用法
  • MyBatis-Flex学习记录1---请各位大神指教
  • 二分查找旋转数组
  • 关于3D位姿旋转
  • 解锁项目成功的关键:项目经理的结构化思维之道
  • 力扣974被K整除的子数组
  • 简单认识Docker数据管理
  • UDP数据报结构分析(面试重点)
  • 【Java 动态数据统计图】动态数据统计思路案例(动态,排序,数组)二(113)
  • C++进阶 类型转换
  • Idea中隐藏指定文件或指定类型文件
  • 第2步---MySQL卸载和图形化工具展示
  • 原型和原型链
  • 解决ios隔空播放音频到macos没有声音的问题