最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
在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是否有对应条目,且HOST、PORT、SERVICE_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 Synced但show database verbose里Transport Lag和Apply 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_standby中process='MRP0'的sequence#是否长时间不动(比如 5 分钟内没变),如果是,立刻去备库alert.log搜ORA-、corruption、undo、gap - 确认是否真开了实时应用:
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_status的error字段,再查v$dataguard_stats的transport lag,最后才跑validate。Broker 的验证是“全量快照”,慢且易误报
validate 和 show 是结果视图,不是诊断入口。真正卡点永远藏在 v$managed_standby 的 sequence# 变化节奏、alert.log 的第一行报错、以及 v$archive_dest_status 的 error 字段里。
相关文章
- 刀剑缭乱2026公测兑换码大全一览 07-05
- 崩坏星穹铁道4.0卡池7个新角色一览 07-05
- 明日方舟终末地开服工业蓝图一览 工业蓝图作用与使用思路解析 07-05
- 原神梦之树怎么开启 梦之树开启条件 07-05
- 帕瓦勇者传说持续伤害阵容搭配推荐 07-05
- 明日方舟:终末地全新玩法 蚀像寻遗怎么玩介绍 07-05