oracle中dg和adg有什么区别

oracle中dg和adg有什么区别

浏览次数:1062次
信息来源: 银河系资源网
更新日期: 2022-05-14
文章简介

区别:1、dg指的是Data Guard数据卫士,拥有备份的功能,能够确保数据的高可用性和数据保护,adg是“Active Data Guard”,可以查询或导出数据,适用于只读性的应用;2、dg读写不能并行,adg的读写可以并行。本教程操...

区别:1、dg指的是Data Guard数据卫士,拥有备份的功能,能够确保数据的高可用性和数据保护,adg是“Active Data Guard”,可以查询或导出数据,适用于只读性的应用;2、dg读写不能并行,adg的读写可以并行。

本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。

oracle中dg和adg有什么区别

DG(Data Guard)

DG(Data Guard,数据卫士)不是一个备份恢复的工具,然而,DG却拥有备份的功能,在物理DG下它可以和主库一模一样,但是它存在的目的并不仅仅是为了备份恢复数据,应该说它的存在是为了确保企业数据的高可用性,数据保护以及灾难恢复。DBA可以通过将一些操作(例如查询报表)转移到备库执行的方式来减小主库的压力,构建高可用的企业数据库应用环境。

在DG环境中,至少有两个数据库,一个处于OPEN状态对外提供服务,这个数据库叫作主库(Primary Database)。第二个处于恢复状态,叫作备库(Standby Database)。在通常情况下,主库对外提供服务,用户在主库上进行操作,操作被记录在联机日志和归档日志中,这些日志通过网络传递给备库,然后在备库上被应用,从而实现主库和备库的数据同步。

Oracle对这一过程进一步地优化设计,使得日志的传递、恢复工作更加自动化、智能化,并且提供一系列参数和命令简化了DBA工作。如果软硬件升级,那么可以把备库切换为主库继续对外服务,这样既减少了服务停止时间,并且数据不会丢失。如果异常原因导致主库不可用,那么也可以把备库强制切换为主库继续对外服务,这时数据损失都和配置的数据保护级别有关系。所以,Primary和Standby只是一个角色概念,并不固定在某个数据库中。

adg

Oracle 11g之前,物理备库(physical Standby)在应用redo的时候,是不可以打开的,只可以mount。从11g开始,在应用redo的时候,物理备库可以处于read-only模式,这就称为Active Data Guard 。通过Active Data Guard,可以在物理备库进行查询或者导出数据,从而减少对主库的访问和压力。

Active Data Guard适用于一些只读性的应用,比如,有的应用程序只是查询数据,进行一些报表业务,不会产生redo数据,这些应用可以转移到备库上,避免对主库资源的争用。

ADG主要解决了DG时代读写不能并行的问题

DG时代的数据同步方式如采用Redo Log的物理方式,则数据库同步数据快、耗用资源低,但存在一个大问题。

Oracle 11G以前的Data Guard物理备份数据库,可以以只读的方式打开数据,但这时日志的数据同步过程就停止了。而如果日志的数据同步处于执行过程中,则数据库就不能打开。也就是日志读、写两个状态是互相排斥的。而Active Data Guard则是主要解决这个问题。

Oracle具有闪回数据库的功能,避免删表等误操作造成无法挽回

当主数据库打开并处于活动状态时,事务处于处理状态,生成Redo Log数据,并将其传送到备用的数据库中,正常情况下,可以做到秒级的数据同步。但如果在主用数据库上执行一个错误的命令,如drop database,则所有备用数据库中的数据也会被删除。

Oracle DG提供了易于使用的方式来避免这种用户错误。DBA可以在主数据库、备用数据库中同时使用闪回数据库功能,以快速将数据库恢复到一个较早的时间点上,从而取消这个误操作。

另外,Oracle还提供了延时执行备份数据库同步的功能,这样又是另一种方式防止误操作。

教程:《Oracle教程》

以上就是oracle中dg和adg有什么区别的详细内容

标签: 暂无标签
oracle怎么修改processes
« 上一篇
oracle怎么设置表空间只读
下一篇 »
  • oracle怎么查询数据库中的所有表名
    811259阅读
    查询方法:1、使用“SELECT * FROM all_tables WHERE OWNER = '用户名'”语句,可查询指定用户的所有表名;2、使用“SELECT * FROM user_tables”语句,可查询当前用户的所有表名。本教程操作环境:Windows7...
  • 总结MySQL常见错误分析与解决方法
    79857阅读
    免费学习:mysql教程一、Can’t connect to MySQL server on ‘localhost’ (10061) 翻译:不能连接到 localhost 上的mysql 分析:这说明“localhost”计算机是存在的,但在这台机器上却没提供MySQL服务。 需要启动这...
  • mysql怎么查询第一列数据
    2493阅读
    在mysql中,可以利用SELECT语句来查询第一列数据,该语句可以根据指定列的字段名来查询数据并输出结果,只需要将“SELECT”关键字后面的字段名设置为需要查找的第一列字段名即可; 语法“SELECT 第一列字段名 FROM 表...
  • oracle怎么查询clob字段数据
    1885阅读
    在oracle中,可以利用instr()函数配合select语句查询clob字段数据,instr函数用于判断字符串是否含有指定的字符,语法为“select*from 表名 ...instr(字段名(clod类型),'查询条件',1,1)”。本教程操作环境:...
  • mysql主从同步如何跳过错误
    1827阅读
    mysql主从同步跳过错误的方法:1、跳过指定数量的事务,代码为【mysql>SET GLOBAL SQL_SLAVE_SKIP..】;2、修改mysql的配置文件,通过【slave_skip_errors】参数来跳所有错误。本教程操作环境:windows7系统、mysql ...
  • oracle怎么判断数据是否是数字类型
    1678阅读
    方法:1、利用“trim(translate(column,'0123456789',' ')) is NULL;”判断数据是否是数字;2、利用“regexp_like(column,'^[0-9]+[0-9]$');”判断数据是否是数字。本教程操作环境:Windows...
  • mysql workbench是什么意思
    1674阅读
    mysql workbench是管理MySQL数据库工具的意思,是一款专门为mysql设计的集成化桌面软件;该软件同时具有开源社区版和收费商业版两个版本,主要用于设计和创建新的数据库图示、建立数据库文档以及进行复杂的mysql迁移...
  • 实例详解oracle添加唯一约束
    1655阅读
    本篇文章给大家带来了关于Oracle的知识,其中主要介绍了添加唯一约束的问题,唯一性约束指表中一个字段或者多个字段联合起来可以唯一标识一条记录的约束,下面一起来看一下,希望对大家有帮助。教程:《Oracle教程》...
  • MySQL索引给拿捏住了
    1587阅读
    本篇文章给大家带来了关于mysql的知识,其中主要介绍了关于mysql索引的问题,包括了索引按照逻辑功能划分、按照物理实现划分、按照字段个数划分等索引类型问题,希望对大家有帮助。学习:mysql教程在 SQL 优化中,索...
  • oracle怎么删除trigger
    1543阅读
    在oracle中,可以利用DROP TRIGGER语句来删除trigger,DROP语句用于进行删除操作,DROP TRIGGER语句的作用就是删除指定的trigger,语法为“DROP TRIGGER 需要删除的trigger名称;”。本教程操作环境:Windows10系统、...

如本文对您有帮助,随意赞赏一下!