Oracle 11g ADG 单实例 DG Broker 配置指南

概述

DataGuard Broker能更加容易的管理和维护多个Standby Database,它能够将主库和备库按照一定的逻辑组织起来并进行集中管理,包括创建、维护和监控 Data Guard 等任务。如果有多个备库或者RAC数据库中有个多个实例,要是进行手工配置管理,就会太过于麻烦,Oracle提供了DataGuard Broker工具,可以在一台服务器上对所有数据库进行统一的配置和管理,这些配置会自动同步到各个数据库中。管理 Broker 设置可以使用 EM 企业管理系统或 DGMGRL 命令行工具。Failover和Switchover可以在DGMGRL工具中是用一条命令切换,大大简化了我们管理的过程。

环境准备
项目 主机名 IP 地址 DB 版本 DB_NAME DB_UNIQUE_NAME
主库 orcldb1 192.168.5.10 11.2.0.4 orcl orcl
备库 orcldb2 192.168.5.11 11.2.0.4 orcl orcl_stb

注意事项:

  • DB_UNIQUE_NAME 主备库不能相同。
  • DB_NAME 主备库需保持一致。
  • 主备库 DB 版本需保持一致。
  • 需要确保Data Guard配置正常。
  • 主库和备库均使用spfile。
步骤详解
一、启用 Broker
  1. 在主库和备库上启用 dg_broker_start 参数

    sql 复制代码
    -- 检查当前设置
    SQL> SHOW PARAMETER dg_broker_start;
    NAME                                 TYPE        VALUE
    ------------------------------------ ----------- ------------------------------
    dg_broker_start                      boolean     FALSE
    
    -- 启用dg_broker_start
    SQL> ALTER SYSTEM SET dg_broker_start = TRUE;
二、配置监听器(Primary 和 Standby)
  1. 编辑 listener.ora 文件

    • 在主库和备库的 listener.ora 文件中添加 DGMGRL 静态监听:

    主库配置:

    bash 复制代码
    SID_LIST_LISTENER =
      (SID_LIST =
        (SID_DESC =
          (GLOBAL_DBNAME = orcl_DGMGRL)
          (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db1)
          (SID_NAME = orcl)
        )
      )

    备库配置:

    bash 复制代码
    SID_LIST_LISTENER =
      (SID_LIST =
        (SID_DESC =
          (GLOBAL_DBNAME = orcl_stb_DGMGRL)
          (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db1)
          (SID_NAME = orcl)
        )
      )
  2. 重启监听器

    bash 复制代码
    $ lsnrctl reload

注意: 如果 listener.ora 文件不配置 DGMGRL 静态监听,SWITCHOVER 将报错 ORA-12514

三、创建和配置 DG Broker
  1. 启动 DGMGRL 命令行工具

    bash 复制代码
    $ dgmgrl sys/oracle@orcl
  2. 创建 Broker 配置

    • 创建 Configuration,名称可以自定义:

      bash 复制代码
      DGMGRL> CREATE CONFIGURATION 'orcl_dg' AS PRIMARY DATABASE IS 'orcl' CONNECT IDENTIFIER IS orcl;
      Configuration "orcl_dg" created with primary database "orcl"
  3. 添加备库

    • 添加备库到 Configuration 中:

      bash 复制代码
      DGMGRL> ADD DATABASE orcl_stb AS CONNECT IDENTIFIER IS orcl_stb MAINTAINED AS PHYSICAL;
      Database "orcl_stb" added
  4. 启用 Configuration

    bash 复制代码
    DGMGRL> ENABLE CONFIGURATION;
    Enabled.
四、检查配置和数据库状态
  1. 显示 Configuration 信息

    bash 复制代码
    DGMGRL> SHOW CONFIGURATION;
  2. 显示主库状态

    bash 复制代码
    DGMGRL> SHOW DATABASE orcl;
  3. 显示备库状态

    bash 复制代码
    DGMGRL> SHOW DATABASE orcl_stb;
五、数据库 Switchover
  1. 从主库切换到备库

    bash 复制代码
    DGMGRL> SWITCHOVER TO orcl_stb;
    Performing switchover NOW, please wait...
    New primary database "orcl_stb" is opening...
    Operation requires shutdown of instance "orcl" on database "orcl"
    Shutting down instance "orcl"...
    ORA-01109: database not open
    Database dismounted.
    ORACLE instance shut down.
    Operation requires startup of instance "orcl" on database "orcl"
    Starting instance "orcl"...
    ORACLE instance started.
    Database mounted.
    Switchover succeeded, new primary is "orcl_stb"
  2. 从备库切回主库

    bash 复制代码
    DGMGRL> SWITCHOVER TO orcl;
六、数据库 Failover
  1. 提前开启 FLASHBACK

    sql 复制代码
    SQL> ALTER DATABASE FLASHBACK ON;
    SQL> ALTER SYSTEM SET db_recovery_file_dest_size = 50G;
  2. 执行 Failover

    bash 复制代码
    DGMGRL> FAILOVER TO orcl_stb IMMEDIATE;
  3. 恢复原主库为备库

    bash 复制代码
    DGMGRL> REINSTATE DATABASE orcl;
七、Snapshot Standby
  1. 激活 Snapshot Standby

    bash 复制代码
    DGMGRL> CONVERT DATABASE orcl_stb TO SNAPSHOT STANDBY;
  2. 切回物理备库

    bash 复制代码
    DGMGRL> CONVERT DATABASE orcl_stb TO PHYSICAL STANDBY;

注意:

  • Snapshot Standby 是 Oracle 11g 的新特性,允许 Physical Standby 数据库短时间内以 Read Write 模式运行。必须是 ADG 才支持。
  • 一旦 Snapshot Standby 被激活的时间超出了 Primary 的最大负载时间,再次的本地更新操作将会产生额外的异常。
总结

通过上述步骤,成功配置 ADG 单实例环境中的 Data Guard Broker。这些步骤不仅简化了 ADG 的管理和维护工作,还提高了系统的可靠性和可用性。

相关推荐
TDengine (老段)5 分钟前
从“数据堆场”到“智能底座”:TDengine IDMP如何统一数据语言
大数据·数据库·物联网·时序数据库·tdengine
l1t44 分钟前
利用短整数类型和部分字符串优化DuckDB利用数组求解数独SQL
开发语言·数据库·sql·duckdb
一 乐1 小时前
医疗管理|医院医疗管理系统|基于springboot+vue医疗管理系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·医疗管理系统
TDengine (老段)2 小时前
从细胞工厂到智能制造:Extracellular 用 TDengine 打通数据生命线
java·大数据·数据库·科技·制造·时序数据库·tdengine
L.EscaRC4 小时前
浅析MySQL InnoDB存储引擎的MVCC实现原理
数据库·mysql
热爱运维的小七5 小时前
MongoDB 内存管理避坑指南:解决高占用、页错误等核心问题,让数据库性能翻倍
数据库·mongodb
冉冰学姐7 小时前
SSM公办小学网络报名系统f3d3p(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·ssm 框架·公办小学网络报名系统·教育信息化
叡鳍8 小时前
hive---HQL查询
数据库
vortex58 小时前
谷歌黑客语法挖掘 SQL 注入漏洞
android·数据库·sql
九河云9 小时前
软件开发平台 DevCloud
运维·服务器·数据库·科技·华为云