当前位置: 首页
数据库
Oracle 12c RAC迁移到19c怎么做?使用Data Guard切换

Oracle 12c RAC迁移到19c怎么做?使用Data Guard切换

热心网友 时间:2026-04-30
转载

Oracle 12c RAC 到 19c RAC 的 Data Guard 切换是否可行?

先说结论:这事儿能办,但路径得选对。它并非一次“原地升级式”的直接切换,而是必须遵循跨版本物理备库搭建、滚动升级、最终切换的标准流程。原因很简单,12c和19c属于不同的主版本,当你尝试执行 alter database commit to switchover 时,版本差异过大(大于一个主版本)会直接触发 ORA-16470 错误。所以,通过物理Data Guard进行在线迁移,是官方唯一支持的稳妥方法。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

为什么不能直接在 12c 主库上建 19c 物理备库?

这里有个核心限制:Oracle不允许跨主版本直接搭建物理备库。问题的关键在于Redo日志格式——19c实例的MRP(托管恢复进程)压根儿识别不了12c主库发来的低版本日志。那么,正确的打开方式是什么呢?答案是,得先让目标端“伪装”成兼容版本。

  • 首先,在计划中的19c RAC环境上,安装与源端完全一致的12.2.0.1数据库软件,并创建一个空实例作为临时备库。
  • 接着,让这个12.2的临时备库正常接收并应用来自12c主库的Redo,保持数据同步。
  • 待同步状态稳定后,在备库侧执行DBUA或手动升级操作至19c(此过程需暂停MRP,升级完成并重启实例后,再重新启动MRP)。
  • 最后,升级完成后务必验证数据字典的一致性(确保catuppst.sql执行无误),并以只读模式打开备库确认数据可访问。至此,才算是具备了执行Switchover的资格。

Data Guard 切换前最关键的三个验证点

这三个验证点,可以说是切换前的“必修课”。跳过任何一步,都极有可能在Switchover过程中卡在 ALTER DATABASE COMMIT TO SWITCHOVER TO PRIMARY 这一步,或者冷不丁地冒出个 ORA-16139(归档日志缺失)错误。

  • 切换状态检查:查询 SELECT SWITCHOVER_STATUS FROM V$DATABASE,返回值必须是 TO PRIMARY。如果看到 SESSIONS ACTIVESWITCHOVER PENDING,那就说明条件还不成熟。
  • 日志同步确认:确保所有归档日志均已传输并应用完毕。执行 SELECT MAX(SEQUENCE#), APPLIED FROM V$ARCHIVED_LOG GROUP BY APPLIED,核对 APPLIED='YES' 的最大序列号,是否与主库当前 LOG_ARCHIVE_DEST_2 目标中的 ARCHIVED_THREAD# 一致。
  • 高级复制进程清理:检查 DBA_LOG_GROUPSDBA_CAPTURE。如果存在已启用的GoldenGate或Streams捕获进程,必须在切换前将其停用。否则,Switchover操作会因为这些未停止的进程而一直挂起。

切换后 19c 新主库上最容易被忽略的配置项

Switchover成功完成,往往让人松一口气,但真正的考验可能才刚刚开始。在19c实例正式接管后,有几个配置细节如果忘了调整,后续的备份、监听甚至集群资源都可能出问题。

  • 监听配置更新local_listener 参数很可能还指向旧的12c SCAN名称或IP地址。需要立即使用类似 ALTER SYSTEM SET LOCAL_LISTENER='(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=rac19-scan)(PORT=1521)))' 的命令进行更新,并在每个节点执行 ALTER SYSTEM REGISTER 使配置生效。
  • 归档路径修正log_archive_dest_1 中的 LOCATION 路径如果仍然写着12c时代的ASM磁盘组名(例如 +FRA12),而19c RAC实际使用的是新磁盘组(如 +FRA19),将直接导致归档失败。必须将其修改为有效的当前路径。
  • 集群资源绑定:OCR(Oracle集群注册表)中的数据库资源名称默认不会自动更新版本号。建议在切换后,运行 srvctl modify database -d xxx -o $ORACLE_HOME 命令,显式地将数据库资源绑定到新的19c Oracle Home目录。

话说回来,19c的 ADG(Active Data Guard)自动间隙修复机制确实比12c更主动。但是,一旦遇到加密钱&包(Wallet)未打开、TDE密钥未同步,或者备用重做日志文件权限不正确等情况,这个“自动”功能就会失效。这些细节问题,在切换前的测试环境中常常难以完全暴露,却非常喜欢在生产割接的关键时刻突然现身,需要格外警惕。

来源:https://www.php.cn/faq/2333444.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
sql语句中数据库别名命名和查询问题解析

sql语句中数据库别名命名和查询问题解析

查询出低于菜品平均价格的菜品信息 (展示出菜品名称、菜品价格) 问题1:为什么下面代码不对 select d name,d price,a vg(d price) from dish as d where d price < a vg(d price) 这行代码一拿出来,很多初学者都会犯迷糊,但其

时间:2026-04-30 20:26
SQLDeveloper表复制的实现

SQLDeveloper表复制的实现

步骤 当数据量比较大时,相比一条条地执行INSERT语句,这种方法效率的提升是立竿见影的。不过,有个关键点需要留心:具体的操作逻辑是直接覆盖目标表原有数据,还是进行增量合并,这个取决于你的工具设置和表结构。稳妥起见,强烈建议你先自己创建一个测试用的Demo表演练一遍,摸清实际行为,避免在生产环境中间

时间:2026-04-30 20:26
SQLServer数据库表结构使用SSMS和Navicat导出教程

SQLServer数据库表结构使用SSMS和Navicat导出教程

在数据库管理和开发过程中,导出表结构是一项常见的任务,尤其是在数据库设计、数据迁移、备份以及生成文档时。本文将详细介绍如何使用 SQL Server Management Studio (SSMS) 和 Na vicat 来导出 SQL Server 数据库的表结构,包括表名、字段名、数据类型、注释

时间:2026-04-30 20:26
MySQL8中的保留关键字陷阱之当表名“lead”引发SQL语法错误的解决方案

MySQL8中的保留关键字陷阱之当表名“lead”引发SQL语法错误的解决方案

问题现象 很多开发者可能都踩过这个坑:一个原本运行得好好的业务系统,在执行下面这条再简单不过的查询时,突然就报错了。 SELECT COUNT(*) AS total FROM lead WHERE deleted_flag = 0 数据库抛出的错误非常明确,直指语法问题: You ha ve an

时间:2026-04-30 20:25
Mysql因为字段字符集编码的问题导致索引没生效的解决方案

Mysql因为字段字符集编码的问题导致索引没生效的解决方案

深入解析SQL查询性能问题:字符集不一致导致的索引失效 SELECT s department_name AS departmentName, cps purchase_type AS purchaseType FROM settlement_records s LEFT JOIN common_p

时间:2026-04-30 20:25
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程