ADG INTRODUCE

Active Data Guard(ADG)是ORACLE 11g企业版的新特性,需要单独的License.可以打开Physical standby至read only模式,standby可以用来做报表系统、查询、排序或Web站点。实时读写分离,以此来分担primary DB的压力。

ADG可以部署在多种商业应用环境中,如:

·通信行业:Schedules服务,自助查询服务。

·医疗行业:快速访问最新的医疗记录。

·金融管理行业:自助查询和报表。

·运输行业:包裹跟踪,订单状态查询。

·商业网站:目录浏览,订单状态,售后产品Reader Farms.

 

ADG特性:

1.实时查询特性,可以打开Physical standby值read only模式并实时应用redo data.

2.启用RMAN block-change tracking。用户利用RMAN在primary的增量备份恢复到standby,性能最高可提升20倍。

Database只读模式下允许的操作:

·SELECT操作,包括需要大量临时段的查询

·ALTER SESSION,ALTER SYSTEM

·SET ROLE

·调用Procedure

·使用DBLINK写数据到远程数据库

·通过DBLINK调用远程数据库的Procedure

·在事务级别读一致性使用SET TRANSACTION READ ONLY

·执行复杂的查询,如:GROUPING SET,WITH查询语句等

Database只读模式下不允许的操作:

·任何DML或DDL操作

·访问本地序列的查询

·对本地临时表的DML操作

ADG的先决条件:

1.ADG选项的license

2.参数COMPATIBLE>=11.0.0

ADG DETAILS

如何检查当前是否启用ADG

SQL> select database_role ,open_mode from v$database;

DATABASE_ROLE      OPEN_MODE

------------------ --------------------

PHYSICAL STANDBY   READ ONLY WITH APPLY

启用ADG

SQL> alter database open read only;

SQL> recover managed standby database disconnect using current logfile;

注:AUDIT_TRAIL参数在数据库打开时可用,read only的standby不支持update,如果AUDIT_TRAIL=DB,则在DB以read only模式打开后,AUDIT_TRAIL参数值会后台转换为OS.

Standby为RAC时,如果应用redo的实例down掉,为保护数据的一致性,ORACLE会关闭其余OPEN READ ONLY的时候至MOUNT状态,需要手工启用另外的实例应用redo.

评估应用是否适合read-only database

参考文档:

Note:1206774.1 - EVENT: 3177 "enable logging of read-only violations"

ADG LAG

standby由于以下的原因可能产生延迟:

- CPU处理能力不足

- 高网络延迟

- 带宽限制

监控LAG:

V$DATAGUARD_STATS

V$STANDBY_EVENT_HISTOGRAM

监控redo apply性能:

V$RECOVERY_PROGRESS

Transport Lag:

SQL> select * from v$dataguard_stats where name='transport lag';

Apply lag:

SQL> select * from v$dataguard_stats where name='apply lag';

查询SCN实时比较primary和standby的LAG:

SQL> create database link standby connect to system identified by 'oracle' using 'standby';

SQL> select scn_to_timestamp((select current_scn from v$database))-scn_to_timestamp((select current_scn from v$database@standby)) LAG from dual;

 

STANDBY_MAX_DATA_DELAT参数:

STANDBY_MAX_DATA_DELAT={INTERGE|NONE},默认NONE,单位:秒,用来指定可容忍的LAG限定,参数为会话级,对SYS用户无效。

如果standby查询超出指定的时间,抛出ORA-3172 STANDBY_MAX_DATA_DELAY has been exceeded.

创建一个trigger,在用户登录时触发设定该参数:

create or replace trigger adg_logon_trigger after logon on app.schema

begin

if (sys_context('userenv', 'database_role') in ('PHYSICAL STANDBY'))

then

execute immediate 'alter session set standby_max_data_delay=5';

endif;

end;

强制redo apply同步:

SQL> alter session sync with primary;

执行此命令后,将会阻塞应用直到standby与primary同步。

创建一个trigger强制用户登录后同步redo apply:

create trigger adg_logon_sync_trigger after logon on user.schema

begin

if (sys_context('userenv','database_role') in ('PHYSICAL STANDBY'))

then

execute immediate 'alter session sync with primary';

end if;

end;

性能提升

11g ADG的性能比10g提升了许多,oracle内部做了一些优化,介质恢复在symmetric multiprocessing (SMP) systems也比之前版本快了许多。

性能提升包括以下几点:

- 更多的并行

- 更高效的异步redo读取、解析和应用

- 减少同步点并行应用算法

- redo log介质恢复时不再阻塞应用下一组日志

Active Data Guard的更多相关文章

  1. DG - 开启Active Data Guard

    在配置active data guard之前,phycial standby必须处于以下两个状态之一: (1)standby处于mount状态,并且redo apply正在运行中 (2)standby ...

  2. Oracle 11gR2 Database和Active Data Guard迁移案例

    客户一套核心系统由一台Oracle Database 11.2.0.3.4单机和一台Active Data Guard组成,分别运行在两台PC服务器上,Oracle Linux 5.8 x86_64b ...

  3. Oracle11g Active Data Guard搭建、管理

    说明:參考网络众多人的笔记及思路,加上自己亲身实践之后的整理笔记.仅供參考. Data Guard与RAC不同的是.在普通情况下.Standby仅仅有一个节点处于活动状态,全部的应用都连接到主serv ...

  4. Oracle Data Guard

    DG 是 Oracle Data Guard 的简称.也就是Oracle11g的 数据卫士. 由于在工作中 Oracle和 SQL SERVER2008 同时都需要维护管理.给我的感觉这里的 DG 其 ...

  5. Oracle 19c Data Guard DML Redirection ADG备库上执行DML重定向(未来更好的进行读写分离)

    资料来自官方网站: https://docs.oracle.com/en/database/oracle/oracle-database/19/sbydb/managing-oracle-data-g ...

  6. 使用Active Database Duplication创建跨平台Data Guard设置 (Windows/Linux) (Doc ID 881421.1)

    Using Active Database Duplication to Create Cross Platform Data Guard Setup (Windows/Linux) (Doc ID ...

  7. 场景7 Data Guard

    场景7  Data Guard 官方文档 :Oracle Data Guard Concepts and Administration 用于数据容灾,通过主备库同步(主库将redo日志传送到备库,一个 ...

  8. 【原】Configuring Oracle Data Guard In Physical Standby Database

    作者:david_zhang@sh [转载时请以超链接形式标明文章] http://www.cnblogs.com/david-zhang-index/p/5042640.html参照文档:https ...

  9. data guard switchover切换异常

    data guard switchover切换异常 查看DG数据库备份库发现,switchover_status为SWITCHOVER LATENT SQL> select OPEN_MODE, ...

随机推荐

  1. SQL流程控制语句

    1 GoTo语句 IF 12>9GOTO print1ELSE GOTO print2 print1:PRINT '执行了流程1'--GOTO theEndprint2:PRINT '执行了流程 ...

  2. Spring AOP 实现数据库读写分离

    背景 我们一般应用对数据库而言都是"读多写少",也就说对数据库读取数据的压力比较大,有一个思路就是说采用数据库集群的方案, 其中一个是主库,负责写入数据,我们称之为:写库: 其它都 ...

  3. Qihoo 360 altas 实践

    Qihoo 360 altas 实践 简介 Atlas是由 Qihoo 360公司Web平台部基础架构团队开发维护的一个基于MySQL协议的数据中间层项目.它在MySQL官方推出的MySQL-Prox ...

  4. 【Git 二】Windows|Mac 安装 Git

    Windows 或 Mac 上安装 Git 相对于 Linux 上安装来说步骤是简便一些的.Linux 安装步骤见:[Git 一]Linux安装Git 一.Windows 安装 Git 直接下载对应 ...

  5. AtCoderBeginner091-C 2D Plane 2N Points 模拟问题

    题目链接:https://abc091.contest.atcoder.jp/tasks/arc092_a 题意 On a two-dimensional plane, there are N red ...

  6. 紫书 习题 10-3 UVa 1643(计算几何 叉乘)

    直观感觉对角线重合的时候面积最大 然后可以根据方程和割补算出阴影部分的面积 注意知道两点坐标,可以求出与原点形成的三角形的面积 用叉乘,叉乘的几何意义以这两个向量为边的平行四边形的面积 所以用叉乘除以 ...

  7. Python学习笔记(3)--数据结构之列表list

    Python的数据结构有三种:列表.元组和字典 列表(list) 定义:list是处理一组有序项目的数据结构,是可变的数据结构. 初始化:[], [1, 3, 7], ['a', 'c'], [1, ...

  8. ids for this class must be manually assigned before calling save():Xxx

    把Xxx.hbm.xml主键生成策略改成identity

  9. 解决Struts中文乱码问题总结

    在进行struts开发的过程中.总也是出现非常多的乱码问题.但归根究竟,也仅仅是下面三种情况:  ㈠页面显示中文乱码  ㈡传递參数中文乱码  ㈢国际化资源文件乱码  以下就这三中情况介绍怎么在详细项目 ...

  10. [python]pip坏了怎么办?

    今天,给一位新同事配置pip,用get-pip.py安装之后.出现错误: raise DistributionNotFound(req)  # XXX put more info here pkg_r ...