一聚教程网:一个值得你收藏的教程网站

热门教程

在Oracle 19c中如何用Data Guard命令行工具诊断同步状态?

时间:2026-07-03 11:08:57 编辑:袖梨 来源:一聚教程网

根本原因是dgmgrl默认走本地监听,需先确认tnsnames.ora中目标别名的HOST、PORT、SERVICE_NAME配置正确且监听已运行,再验证db_unique_name一致性,而非直接调整dg_broker_start。

用 dgmgrl 连不上或报 ORA-12541 怎么办

根本原因不是 broker 没配,而是 dgmgrl 默认走的是本地监听,而备库或主库的监听可能没开、端口不对、或 tnsnames.ora 里没定义目标别名。别急着改 dg_broker_start,先确认连接串能通。

  • 执行 dgmgrl sys/password@db_unique_name 前,先用 sqlplus / as sysdba 登进去查 select db_unique_name from v$database;,确保你写的别名和实际值一致
  • 检查 $ORACLE_HOME/network/admin/tnsnames.ora 是否有对应条目,且 HOSTPORTSERVICE_NAME 都指向正确的实例(注意:不是 SID,是 SERVICE_NAME,通常是 db_unique_name_DGMGRL
  • 如果只是临时诊断,直接用 dgmgrl /(操作系统认证)进本地实例,再用 connect sys/password@db_unique_name 切过去,绕过 tns 解析环节

show configuration 输出 Warning 或 Not Synced 是什么信号

Broker 的 show configuration 不只是“好看”,它会暴露底层配置缺陷。Warning 往往不是日志没传,而是参数或结构不合规。

  • Warning: ORA-16607: one or more databases have failed —— 多数是备库 dg_broker_start=false 或 DMON 进程没起来,查 ps -ef | grep dmon
  • Warning: standby redo log files not configured —— 物理 DG 必须配 SRL,否则无法实时应用;数量至少比在线日志多一组,大小一致,且要 alter database add standby logfile 显式添加
  • Status 显示 Not Syncedshow database verboseTransport LagApply Lag 都是 +00 00:00:00?那大概率是 Broker 自身状态缓存未刷新,执行 validate database 强制重检

为什么 show database verbose 里 Apply Lag 一直涨,但 v$managed_standby 显示 MRP0 正常

Apply Lag 持续增长,说明日志在备库积压没应用完,但 v$managed_standby 看起来“一切正常”,这通常意味着 MRP0 在跑,但卡在某条日志上没推进。

  • 先查 v$managed_standbyprocess='MRP0'sequence# 是否长时间不动(比如 5 分钟内没变),如果是,立刻去备库 alert.logORA-corruptionundogap
  • 确认是否真开了实时应用:select recovery_mode from v$archive_dest_status where dest_id = 2; 返回 MANAGED REAL TIME APPLY 才算启用;若为 MANAGED STANDBY,Apply Lag 天然存在,属设计行为
  • 检查 v$archive_gap —— 它只反映接收缺口,不反映应用卡点;但如果有记录,说明 RFS 根本没收到日志,问题在传输层而非应用层

validate database 报 ORA-16653 或 ORA-16778 怎么快速定位

这两个错误都指向版本或兼容性硬伤,不是重启能解决的。尤其在跨版本升级场景下,Broker 的 validate 会直接拒绝通过。

  • ORA-16653: database is not in a valid state for the operation —— 典型于 11g 主库 + 19c 备库物理 DG 场景,Broker 拒绝管理混合版本。必须转逻辑 DG,且主库需先执行 exec dbms_logstdby.build
  • ORA-16778: redo transport error on standby database —— 表面是传输错,实则常因主库 log_archive_dest_2 参数里 DB_UNIQUE_NAME 写错,或备库监听未注册服务名(lsnrctl status 看输出里有没有 db_unique_name_DGMGRL
  • 别依赖 validate 一次过:先手工查 v$archive_dest_statuserror 字段,再查 v$dataguard_statstransport lag,最后才跑 validate。Broker 的验证是“全量快照”,慢且易误报
Broker 的 validateshow 是结果视图,不是诊断入口。真正卡点永远藏在 v$managed_standbysequence# 变化节奏、alert.log 的第一行报错、以及 v$archive_dest_statuserror 字段里。

热门栏目