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

概述

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

环境准备
项目主机名IP 地址DB 版本DB_NAMEDB_UNIQUE_NAME
主库orcldb1192.168.5.1011.2.0.4orclorcl
备库orcldb2192.168.5.1111.2.0.4orclorcl_stb

注意事项:

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

    -- 检查当前设置
    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 静态监听:

    主库配置:

    SID_LIST_LISTENER =(SID_LIST =(SID_DESC =(GLOBAL_DBNAME = orcl_DGMGRL)(ORACLE_HOME = /u01/app/oracle/product/11.2.0/db1)(SID_NAME = orcl)))
    

    备库配置:

    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. 重启监听器

    $ lsnrctl reload
    

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

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

    $ dgmgrl sys/oracle@orcl
    
  2. 创建 Broker 配置

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

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

    • 添加备库到 Configuration 中:

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

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

    DGMGRL> SHOW CONFIGURATION;
    
  2. 显示主库状态

    DGMGRL> SHOW DATABASE orcl;
    
  3. 显示备库状态

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

    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. 从备库切回主库

    DGMGRL> SWITCHOVER TO orcl;
    
六、数据库 Failover
  1. 提前开启 FLASHBACK

    SQL> ALTER DATABASE FLASHBACK ON;
    SQL> ALTER SYSTEM SET db_recovery_file_dest_size = 50G;
    
  2. 执行 Failover

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

    DGMGRL> REINSTATE DATABASE orcl;
    
七、Snapshot Standby
  1. 激活 Snapshot Standby

    DGMGRL> CONVERT DATABASE orcl_stb TO SNAPSHOT STANDBY;
    
  2. 切回物理备库

    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 的管理和维护工作,还提高了系统的可靠性和可用性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/62963.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据采集卡的各参数介绍

数据采集卡(DAQ 卡)是用于测量物理信号(如电压、电流、温度等)并将其转化为数字信号的设备。 1. 通道数(Channels) 含义:数据采集卡可以同时采集多少路信号。比喻:通道数就像一个人…

LeetCode 力扣 热题 100道(十四)二叉树的中序遍历(C++)

给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。 如下为代码: /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullpt…

运费微服务和redis存热点数据

目录 运费模板微服务 接收前端发送的模板实体类 插入数据时使用的entity类对象 BaseEntity类 查询运费模板服务 新增和修改运费模块 整体流程 代码实现 运费计算 整体流程 总的代码 查找运费模板方法 计算重量方法 Redis存入热点数据 1.从nacos导入共享redis配置…

【C++】—— set 与 multiset

【C】—— map 与 set 1 序列式容器和关联式容器2 set 系列的使用2.1 set 和 multiset 参考文档2.2 set 类的介绍2.3 set 的迭代器和构造2.4 set的增删查2.4.1 insert2.4.2 find 与 erase2.4.3 count 2.5 lower_bound 与 upper_bound2.6 multiset 与 set 的差异2.6.1 不再去重2…

HTML5系列(11)-- Web 无障碍开发指南

前端技术探索系列:HTML5 Web 无障碍开发指南 ♿ 致读者:构建人人可用的网络 👋 前端开发者们, 今天我们将深入探讨 Web 无障碍开发,学习如何创建一个真正包容、人人可用的网站。让我们一起为更多用户提供更好的网络…

dockers网络连接指令:docker network connect

docker network connect 是 Docker 提供的一个命令,用于将现有的容器连接到一个指定的网络中。通过这个命令,用户可以让容器加入到不同的网络环境中,从而实现容器间的通信或者与外部网络的交互。一旦容器被连接到某个网络,它就能够与其他同处该网络中的容器进行直接通信,而…

Jupyter Notebook认识、安装和启动以及使用

Jupyter Notebook认识、安装和启动以及使用 Jupyter Notebook认识、安装和启动以及使用 Jupyter Notebook认识、安装和启动以及使用一、认识Jupyter Notebook1.1 Jupyter Notebook概述1.2 Jupyter Notebook 重要特性(1)交互式代码执行(2)支持多种编程语言(3)富文本编辑(4)代码高…

算法第一弹-----双指针

目录 1.移动零 2.复写零 3.快乐数 4.盛水最多的容器 5.有效三角形的个数 6.查找总价值为目标值的两个商品 7.三数之和 8.四数之和 双指针通常是指在解决问题时,同时使用两个指针(变量,常用来指向数组、链表等数据结构中的元素位置&am…

Java 按照添加顺序的集合 详解

在 Java 中,若需要按照添加顺序存储和操作元素,有以下几种数据结构可供选择。这些结构在保留元素插入顺序的同时提供了不同的功能特性。 1. 使用 ArrayList 特点 有序性:ArrayList 会按添加顺序存储元素。允许重复:可以存储重复…

【后端面试总结】golang channel深入理解

在Go语言中,Channel是一种用于在goroutine之间进行通信和同步的重要机制。它提供了一种安全、类型安全的方式来传递数据,使得并发编程变得更加直观和简单。本文将详细介绍Golang中Channel的基本概念、创建与关闭、发送与接收操作,以及相关的使…

java使用HttpClient发送数据的几种情况

1.发送Http 携带 json格式的数据 import org.apache.commons.compress.utils.IOUtils; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.methods.HttpPost; import org.apache.http.entity.StringEntity; import org…

稳定运行的以Azure Synapse Dedicated SQL Pool数据仓库为数据源和目标的ETL性能变差时提高性能方法和步骤

在Azure Synapse Dedicated SQL Pool(以前称为SQL Data Warehouse)的ETL性能变差时,可以通过以下方法和步骤来提高性能: 1. 分析和监控性能瓶颈 查看执行计划:使用SQL的SET STATISTICS IO ON和SET STATISTICS TIME O…

华为、华三交换机纯Web下如何创关键VLANIF、操作STP参数

华为交换机WEB操作 使用的是真机S5735,目前主流的版本都适用(V1R5~V2R1的就不在列了,版本太老了,界面完全不一样,这里调试线接的console口,电脑的网络接在ETH口) 「模拟器、工具合集」复制整段内…

OpenCL介绍

OpenCL(Open Computing Language)详解 OpenCL 是一个开源的框架,用于编写在异构平台(包括中央处理单元(CPU)、图形处理单元(GPU)、数字信号处理器(DSP)和其他…

项目搭建:springboot,mybatis, maven

创建一个基于Spring Boot、MyBatis和Maven的项目可以简化很多配置,因为Spring Boot自带了很多自动配置的功能。下面我将给出一个简单的示例来展示如何搭建这样一个项目。 ### 1. 创建一个新的Spring Boot项目 你可以通过Spring Initializr(https://sta…

详解Java数据库编程之JDBC

目录 首先创建一个Java项目 在Maven中央仓库下载mysql connector的jar包 针对MySQL版本5 针对MySQL版本8 下载之后,在IDEA中创建的项目中建立一个lib目录,然后把刚刚下载好的jar包拷贝进去,然后右键刚刚添加的jar包,点击‘添…

网络(TCP)

目录 TCP socket API 详解 套接字有哪些类型?socket有哪些类型? 图解TCP四次握手断开连接 图解TCP数据报结构以及三次握手(非常详细) socket缓冲区以及阻塞模式详解 再谈UDP和TCP bind(): 我们的程序中对myaddr参数是这样…

【笔记】离散数学 1-3 章

1. 数理逻辑 1.1 命题逻辑的基本概念 1.1.1 命题的概念 命题(Proposition):是一个陈述句,它要么是真的(true),要么是假的(false),但不能同时为真和假。例如…

【Linux篇】权限管理 - 用户与组权限详解

一. 什么是权限? 首先权限是限制人的。人 真实的人 身份角色 权限 角色 事物属性 二. 认识人–用户 Linux下的用户分为超级用户和普通用户 root :超级管理员,几乎不受权限的约束普通用户 :受权限的约束超级用户的命令提示符是#,普通用…

【机器学习】机器学习的基本分类-监督学习-决策树-C4.5 算法

C4.5 是由 Ross Quinlan 提出的决策树算法,是对 ID3 算法的改进版本。它在 ID3 的基础上,解决了以下问题: 处理连续型数据:支持连续型特征,能够通过划分点将连续特征离散化。处理缺失值:能够在特征值缺失的…