Oracle 12c RAC迁移到19c怎么做?使用Data Guard切换
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 ACTIVE或SWITCHOVER PENDING,那就说明条件还不成熟。 - 日志同步确认:确保所有归档日志均已传输并应用完毕。执行
SELECT MAX(SEQUENCE#), APPLIED FROM V$ARCHIVED_LOG GROUP BY APPLIED,核对APPLIED='YES'的最大序列号,是否与主库当前LOG_ARCHIVE_DEST_2目标中的ARCHIVED_THREAD#一致。 - 高级复制进程清理:检查
DBA_LOG_GROUPS和DBA_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密钥未同步,或者备用重做日志文件权限不正确等情况,这个“自动”功能就会失效。这些细节问题,在切换前的测试环境中常常难以完全暴露,却非常喜欢在生产割接的关键时刻突然现身,需要格外警惕。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
sql语句中数据库别名命名和查询问题解析
查询出低于菜品平均价格的菜品信息 (展示出菜品名称、菜品价格) 问题1:为什么下面代码不对 select d name,d price,a vg(d price) from dish as d where d price < a vg(d price) 这行代码一拿出来,很多初学者都会犯迷糊,但其
SQLDeveloper表复制的实现
步骤 当数据量比较大时,相比一条条地执行INSERT语句,这种方法效率的提升是立竿见影的。不过,有个关键点需要留心:具体的操作逻辑是直接覆盖目标表原有数据,还是进行增量合并,这个取决于你的工具设置和表结构。稳妥起见,强烈建议你先自己创建一个测试用的Demo表演练一遍,摸清实际行为,避免在生产环境中间
SQLServer数据库表结构使用SSMS和Navicat导出教程
在数据库管理和开发过程中,导出表结构是一项常见的任务,尤其是在数据库设计、数据迁移、备份以及生成文档时。本文将详细介绍如何使用 SQL Server Management Studio (SSMS) 和 Na vicat 来导出 SQL Server 数据库的表结构,包括表名、字段名、数据类型、注释
MySQL8中的保留关键字陷阱之当表名“lead”引发SQL语法错误的解决方案
问题现象 很多开发者可能都踩过这个坑:一个原本运行得好好的业务系统,在执行下面这条再简单不过的查询时,突然就报错了。 SELECT COUNT(*) AS total FROM lead WHERE deleted_flag = 0 数据库抛出的错误非常明确,直指语法问题: You ha ve an
Mysql因为字段字符集编码的问题导致索引没生效的解决方案
深入解析SQL查询性能问题:字符集不一致导致的索引失效 SELECT s department_name AS departmentName, cps purchase_type AS purchaseType FROM settlement_records s LEFT JOIN common_p
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

