Oracle学习之DATAGUARD(一) DG架构

DataGuard运行原理非常简单:传输日志、应用日志。下图表示了DG的基本架构

  1. 日志传输服务将主库产生的日志数据传到从库。
  2. 应用服务(Apply Service)验证日志数据,并且更新从库的数据文件。
  3. 主数据库的写进程更新数据文件,并不依赖于DataGuard架构。
  4. 当网络或者从库故障恢复时,DG自动重传已经被主库归档的日志数据。
  • 日志传输服务Redo Transport Services

Redo Transport Services协调主从库之间的日志传输。当主库LGWR写日志时,Log Network Server (LNS)程序从Log buffer cache中读取日志数据,通过Oracle Net Services将数据传输到从库上。从库上的Remote File Server (RFS)接收传过来的日志。RFS将接收到的日志写到standby redo log file (SRL).在多从库环境下,主库为每个从库都启用一个独立的LNS进程,用来传输日志数据。

使用LNS进程,DataGuard支持两种日志传输方式:同步、异步。

同步日志传输Synchronous Redo Transport

Synchronous transport (SYNC) 也被称为"零数据丢失"。只有当LNS确认日志被传输到从库并且已经写入磁盘后,主库上的commit操作才会被认为成功。

Data Guard 日志传输进程架构

SYNC redo transport architecture

  1. 用户commit一个事务,将在Redo Buffer中生成一些redo record 。LGWR从Log buffer中读取redo record并将其写入Online Redo Logs,于此同时等待LNS进程的确认。
  2. LNS从Redo Buffer中读取相同的redo record,通过ONS将其传输到从库。RFS接收日志,将其写入Standby Redo Logs。
  3. 当RFS写日志成功后,传输一个确认信号给主库上的LNS,LNS将此确认信息告知LGWR。此时LGWR才能反馈给用户提交成功的信息。
时间: 2024-10-13 19:29:29

Oracle学习之DATAGUARD(一) DG架构的相关文章

Oracle学习之DATAGUARD(二) DG架构--应用服务

DataGuard提供了两种不同的方法应用日志到standby数据库:Redo Apply (物理备库).SQL Apply(逻辑备库). DG的主要目标是保护数据库数据不会丢失.另一个目标是提供主从库之间的高度隔离. 物理备库: Redo Apply使用介质恢复的方法,从SRL中读出redo record放在内存中,然后直接应用change vectors恢复从库数据.主库和从库之间是块对块的物理复制品.介质恢复可以并发的对数据进行恢复,以提供更高的性能.在11g之间,物理备库的恢复只能在mo

Oracle学习之DATAGUARD(四) 在同台机器上搭建DG

1. 建立一个primary数据库,db_name等都为primary. 2. 启用归档模式 SQL> archive log list Database log mode        No Archive Mode Automatic archival        Disabled Archive destination        USE_DB_RECOVERY_FILE_DEST Oldest online log sequence     1 Current log sequenc

Oracle学习之DATAGUARD(十) 在同台机器上使用11g rman新特性创建DG

首先使用dbca建立一个数据库,db_name=primary . 2.   为两个数据库准备静态监听.及连接彼此的TNSNAME 11gdg1-> cat listener.ora tnsnames.ora  # listener.ora Network Configuration File: /u01/app/oracle/product/11.2.0/db_1/network/admin/listener.ora # Generated by Oracle configuration to

Oracle学习之DATAGUARD(六) 创建和启用Broker配置

DataGuard Broker是一个分布式管理架构用于自动创建.维护和监视dataguard配置.你可以使用OEM(图像化界面)或者DGMGRL(命令行方式)进行以下操作:1.创建和激活dataguard配置,包括设置redo transport services and log apply services2.可以在任何系统管理这个配置中的整个dataguard配置(所有的主库和备库)3.管理和监视包含RAC primary或standby数据库的dataguard配置4.简化角色切换操作,

Oracle学习之DATAGUARD(八) Switchover与failover

Switchover是将主从库角色切换,无损转换,通常是用户手动触发或者有计划的让其自动触发,比如硬件升级啦,软件升级啦之类的.而failover是当主库发生故障时,如何将从库切换成主库. 一.如何使用sql命令进行switchover . 检查主库是否支持switchover操作 登录数据库,执行如下查询 SQL> select switchover_status from v$database; SWITCHOVER_STATUS ------------------------------

Oracle学习之DATAGUARD(五) 创建logic standby

逻辑备库与物理备库不同,它并不是Primary数据库的一个精确的copy.同一rowid,在逻辑备库上返回的值并不是相同的.有些数据类型或者对象,逻辑备库并不支持同步.在创建逻辑备库之前,你首先要确认,哪些schema及对象是不被SQL-APPLY支持的. 1. 查询不被同步的schema . SQL> set pagesize 200 SQL> SELECT OWNER FROM DBA_LOGSTDBY_SKIP WHERE STATEMENT_OPT = 'INTERNAL SCHEMA

Oracle学习之DATAGUARD(十一) snapshot database

Snapshot Standby,此功能可将备库置身于"可读写状态"用于不方便在生产环境主库中测试的内容,比如模拟上线测试等任务.当备库读写状态下任务完成后,可以非常轻松的完成Snapshot Standby数据库角色切换回备库角色,恢复与主库数据同步.在Snapshot Standby数据库状态下,备库是可以接受主库传过来的日志,但是不能够将变化应用在备库中. 物理备库要转换成Snapshot的前提条件 停止备库上的日志应用. 备库开启数据库闪回功能 下面演示,如果切换成snapsh

Oracle学习之DATAGUARD(三) 使用11gRMAN新特性搭建standby

环境描述:有两台机器,11gdg1.11gdg2 .11gdg1上安装了数据库dgtst . 11gdg2上只安装了Oracle软件,并没有安装数据库.以下描述如何在11gdg2上建立一个standby 数据库. 一. standby 数据库准备 1.1 创建从库的静态监听. 11gdg2-> cat /u01/app/oracle/product/11.2.0/db_1/network/admin/listener.ora  # listener.ora Network Configurati

Oracle 10g 物理Dataguard日常操作维护(二)

3.3进程日志的监控操作 3.3.1 查看备库进程状态 SQL>select process,client_process,sequence#,status from v$managed_standby PROCESS   CLIENT_P  SEQUENCE#    STATUS ---------       --------     ---------- -      ----------- ARCH      ARCH            153       CLOSING ARCH