DG_Oracle DataGuard作用和概念(概念)
2014-06-03 Created By BaoXinjian
 
Oracle DataGuard是Oracle自带的数据同步功能,基本原理是将日志文件从原数据库传输到目标数据库,然后在目标数据库上应用这些日志文件,从而使目标数据库与源数据库保持同步,是一种数据库级别的高可用性方案。
DataGuard可以提供Oracle数据库的冗灾、数据保护、故障恢复等,实现数据库快速切换与灾难性恢复。
在生产数据库的保证"事务一致性"时,使用生产库的物理全备份创建备库,备库会通过生产库传输过来的归档日志或重做条目自动维护备用数据库。
DataGuard数据同步技术有以下优势:
1. Oracle数据库自身内置的功能,与每个Oracle新版本的新特性都完全兼容,且不需要另外付费。
2. 配置管理较简单,不需要熟悉其他第三方的软件产品。
3. 物理Standby数据库支持任何类型的数据对象和数据类型。
4. 逻辑Standby数据库处于打开状态,可以在保持数据同步的同时执行查询等操作。
5. 在最大保护模式下,可确保数据的零丢失。
Oracle DataGuard由一个Primary数据库(生产数据库)及一个或多个Standby数据库(最多9个)组成。组成Data Guard的数据库通过Oracle Net连接,并且有可以分布于不同地域。
只要各库之间可以相互通信,它们的物理位置并没有什么限制,不受操作系统的限制。
1. Primary 数据库
DataGuard包含一个Primary数据库即被大部分应用访问的生产数据库,该库既可以是单实例数据库,也可以是RAC。
2. Standby 数据库
Standby数据库是Primary数据库的复制(事务上一致)。在同一个Data Guard中可以最多创建9个standby数据库,一旦创建完成,Data Guard通过应用Primary数据库的redo自动维护每一个Standby数据库。
Standby数据库同样即可以是单实例数据库,也可以是RAC结构。
3. 结构图
Standby数据库通常分两类:逻辑standby和物理standby。
1. 逻辑standby
a. 逻辑standby是通过接收primary数据库的redo log并转换成sql语句,然后在standby数据库上执行SQL语句实现同步;
b. 与主库共享同样的模式定义;
c. 通过应用SQL(sql apply)与主库保持一致;
d. 当从主库接受到日志后,逻辑备用数据库是通过logmnr将日志转换成sql,在逻辑备库的表中,表可以同时用于恢复,报表查询功能;
2. 物理standby
a. 物理standby是通过接收并应用primary数据库的redo log以介质恢复的方式实现同步,不仅文件的物理结构相同,连块在磁盘上的存储位置都是一模一样的;
b. 基于数据块级别和主数据库一致;
c. 通过应用日志(redo apply)与主库保持同步;
d. 在mount standby阶段进行应用日志恢复,而同时也可以open read only提供报表查询;
1. 物理备库
(1). Managed recovery state
该模式下log transport service归档日志到备库,log apply service 自动应用这些日志。数据库不处于mount状态,任何读都不允许。
(2). Read only state
如果我们想做备库为报表功能,那么在备库环境中,我们以read only形式打开数据库。在备库log apply service将不能够应用归档日志到备库,但是主库的log transport service可以继续传递归档日志到备库。
我们可以非产轻松的在上述两种运行下进程切换,一般情况下我们会在如下的场景下进程切换:
a. 物理备库用于报表模式
b. 为了灾难的保护,检查数据是否正常的传递到了备库
2. 逻辑备库
Open read write mode
该种模式,备库仍然可以不断的应用归档日志,但是该备库同时可以提供报表查询功能。
当log apply service正在更新一张表时,该表仍然可以查询,但是在该表上无法做任何的DML操作。如果其他模式下的对象没有被log apply service所维护,那么我们可以更新该模式下的那些对象。
1. 重做传输服务(Redo Transport Services)
控制redo数据的传输到一个或多个归档目的地。
2. 日志应用服务(Log Apply Services)
应用redo数据到standby数据库,以保持与primary数据库的事务一致。redo数据即可以从standby数据库的归档文件读取,也可直接应用备用日志文件读取。
3. 角色转换服务(Role Transitions)
DataGuard中有两种角色:primary和standby。角色转换就是让数据库在这两个角色中切换,
4. 切换分两种:switchover和failover
(1). switchover:
a. 转换primary数据库与standby数据库。
b. switchover可以确保不会丢失数据。
c. 计划中角色转换,主要用于操作系统和硬件的维护,备库切换成主库,而主库切换成备库,在切换完成后,这个过程没有任何的数据丢失和损失。
(2). failover:
a. 当primary数据库出现故障并且不能被及时恢复时,会调用failover将一个standby数据库转换为新的primary数据库。
b. 在最大保护模式或最高可用性模式下,failover可以保证不会丢失数据。
c. 非计划中的角色转换,在紧急情况下使用,根据数据的保护模式的不同,只有少量的或者是很少的数据损失
1. 最大保护
这种模式是默认的数据保护模式,在不影响源数据库性能的条件下提供尽可能高的数据保护等级。
在该种模式下,一旦日志数据写到源数据库的联机日志文件,事务即可提交,不必等待日志写到目标数据库,如果网络带宽充足,该种模式可提供类似于最大可用模式的数据保护等级。
2. 最大可用性
这种模式和"最大保护"基本上差不多。正常情况下,主备库之间是同步的。
当网络或者备库出现问题时,不会影响到主库的当机,主库会自动转换库"最大性能"模式,等待备库可用时,将归档传输到备库做恢复。
3. 最大性能
这种模式保证主库性能最大化,主备库之间数据是异步传输的。
即,主备日志归档以后才会传输到备用库,在备库上使用归档日志文件做恢复操作。
运行DataGuard需要具备以下几个条件:
1. 在主库和从库的所有机器上必须安装同一个版本的Oracle企业版。
2. 主库必须运行在归档模式下。
3. 主库和从库的操作系统必须一样(允许版本不同),从库可以使用与主库不同的目录结构。
4. 主从库硬件系统的体系结构必须相同。比如:主库运行在64位的Sun Sparc系统上,如果从库是32位的Linux Intel系统就不允许。主从库硬件的配置可以不同,比如:CPU数量、内存大小、存储配置等。
Thanks and Regards
参考:百度文库 - http://wenku.baidu.com/
参考:Anpiter - http://blog.chinaunix.net/uid-14877370-id-2782040.html
												
DG_Oracle DataGuard作用和概念(概念)的更多相关文章
- Maven介绍,包括作用、核心概念、用法、常用命令、扩展及配置
		
由浅入深,主要介绍maven的用途.核心概念(Pom.Repositories.Artifact.Build Lifecycle.Goal).用法(Archetype意义及创建各种项目).maven常 ...
 - Java 泛型的作用及其基本概念
		
一.泛型的基本概念 java与c#一样,都存在泛型的概念,及类型的参数化.java中的泛型是在jdk5.0后出现的,但是java中的泛型与C#中的泛型是有本质区别的,首先从集合类型上来说,java 中 ...
 - [转]Maven介绍,包括作用、核心概念、用法、常用命令、扩展及配置
		
转自:http://www.trinea.cn/android/maven/ 两年半前写的关于Maven的介绍,现在看来都还是不错的,自己转下.写博客的一大好处就是方便自己以后查阅,自己总结的总是最靠 ...
 - java泛型的作用及其基本概念
		
一.泛型的基本概念 java与c#一样,都存在泛型的概念,及类型的参数化.java中的泛型是在jdk5.0后出现的,但是java中的泛型与C#中的泛型是有本质区别的,首先从集合类型上来说,java 中 ...
 - DG_Oracle DataGuard Primary/Standby物理主备节点安装实践(案例)
		
2014-09-09 Created By BaoXinjian
 - DG_Oracle DataGuard Failover主备节点切换(案例)
		
2014-03-09 Created By BaoXinjian Thanks and Regards
 - DG_Oracle DataGuard Switchover主备节点切换(案例)
		
2014-06-09 Created By BaoXinjian Thanks and Regards http://wenku.baidu.com/view/dc9f00d349649b6648d7 ...
 - .NET Remoting学习笔记(一)概念
		
目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 背景 自接触编程以来,一直听过这个名词Remotin ...
 - 4.事务提交过程,交易的基本概念,Oracle交易周期,保存点savepoint,数据库的隔离级别
		
 事务提交过程 事务 基本概念 概念:一个或者多个DML语言组成 特点:要么都成功.要么都失败 事务的隔离性:多个client同一时候操作数据库的时候.要隔离它们的操作, 否则出现:脏读 不可反 ...
 
随机推荐
- scala言语基础学习三
			
map的操作 访问fangwemap元素 修改map元素 遍历map sortmap和linkmap map元素类型tuple
 - POJ2375 Cow Ski Area (强连通)(缩点)
			
Cow Ski Area Time Limit: 1000MS Memory Limit: 65536K Total Sub ...
 - android中常见对话框之一AlertDialog
			
在Android应用中,有多种对话框:Dialog.AlertDialog.ProgressDialog.时间.日期等对话框. (1)Dialog类,是一切对话框的基类,需要注意的是,Dialog类虽 ...
 - Android——AutoCompleteTextView、Spinner和消息提示
			
layout文件: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:an ...
 - 如何在python3.3用 map filter reduce
			
在3.3里,如果直接使用map(), filter(), reduce(), 会出现 >>> def f(x): return x % 2 != 0 and x % 3 != 0 ...
 - GlassFish Server is a compliant implementation of the Java EE 7 platform
			
1.9 GlassFish Server Tools GlassFish Server is a compliant implementation of the Java EE 7 platform. ...
 - Qt QTreeWidget节点的添加+双击响应+删除详解(转)
			
QTreeWidget是实现树形结构的类,在很多软件中都可以看到类似树形结构的界面. 我做的一个示例如下图,用来处理图像,最顶层节点是图像的路径名,子节点是图像的各个波段,双击各个波段会显示图像各波段 ...
 - 3D知识补充
			
Light Mapping = Dark Mapping (光照映射.黑暗映射) 本质上也是多贴一张图,他是做相乘操作.第2张纹理通常中间亮,外面暗.如果是简单的 Modulate,那么实际上所有像素 ...
 - argparse
			
import argparse def test(a,b): print int(a)+int(b) parser = argparse.ArgumentParser() parser.add_arg ...
 - axure 母版 模板
			
axure的模板区域是非常重要的一个功能,网站的头部.尾部部分等很多页面同时用到的内容,都可以使用母版,因为在母版中只需要修改一次,就可以实现所有的页面更新,可以大大的加速原型的制作速度.需要重复理解 ...