dataguard


dataguard

文章插图
dataguard【dataguard】DataGuard是甲骨文推出的一种高可用性资料库方案,在Oracle 8i之前被称为Standby Database 。从Oracle 9i开始,正式更名为Data Guard 。它是在主节点与备用节点间通过日誌同步来保证数据的同步,可以实现资料库快速切换与灾难性恢复 。Data Guard只是在软体上对资料库进行设定,并不需要额外购买任何组件 。用户能够在对主资料库影响很小的情况下,实现主备资料库的同步 。而主备机之间的数据差异只限于线上日誌部分,因此被不少企业用作数据容灾解决方案 。
基本介绍外文名:dataguard
主要功能:冗灾、数据保护、故障恢复等
概述:一种资料库级别的HA方案
类型:"物理standby"和"逻辑standby"
方案概述DataGuard是一种资料库级别的HA方案,最主要功能是容灾数据保护、故障恢复等 。DataGuard是生产资料库的"事务一致性copy",创建时,使用生产库的物理copy.创建完成后,备库会通过生产库传输过来的归档日誌(或重做条目)自动维护备用资料库 。将重做数据套用到备用库 。类型DataGuard分为"物理standby"和"逻辑standby"物理standby主备库之间物理结构,逻辑结构保持一致 。通常情况下备用库通过主库传输过来的归档日誌做恢复 。基于"块对块"方式 。与主资料库相同 。物理standby等同于生产库 。物理standby能以read only方式打开(或者在flashback资料库下以"读写方式打开") 。物理standby一旦以"读写"方式打开,备用库将不会从主资料库接受重做数据 。只有当备库flashback到过去的点,当备用库flashback到"读写"打开时间点前的状态时,DataGuard会自动同步备库与主库 。才能恢复standby角色 。逻辑standby只保证逻辑结构与主库一致 。备用库要处于打开状态,通过从主库归档日誌档案中提取出来的SQL语句做恢复 。创建时,与物理standby一样,使用主库copy.逻辑备库通过执行SQL语句来更新 。DataGuard转换日誌档案中的数据为SQL语句,然后在逻辑standby上执行SQL语句.因为逻辑standby是通过SQL语句来实现数据同步,那幺在同步期间其必须保持打开状态 。服务1.重做传输服务控制重做数据从生产机传输到一个或多个备用库 。2.日誌套用服务2.1 生产库上通过ARCH进程生成归档日誌档案,然后传输到备用库,备用库再从归档日誌中恢複数据2.2 实时模式时,生产库上的操作通过LGWR进程实时反映在备用库的备用日誌档案中,备用库从备用日誌档案实时恢複数据 。3.角色切换主备库用户角色的切换 。三种保护模式1.最大保护这种模式主备库之间数据是同步的 。即主库提交的同时,备库会做相应的恢复 。最大限度的保证了数据完整性 。不允许数据的丢失 。如果主备库之间网路,或者备库出现问题会直接影响主库操作 。导致主库宕机 。2.最大可用性这种模式和"最大保护"基本上差不多 。正常情况下,主备库之间是同步的 。当网路或者备库出现问题时,不会影响到主库的宕机,主库会自动转换库"最大性能"模式,等待备库可用时,将归档传输到备库做恢复 。可以把这种模式理解为"最大保护"和"最大性能"两种模式的中间体 。3.最大性能这种模式保证主库性能最大化,主备库之间数据是异步传输的 。即,主库日誌归档以后才会传输到备用库,在备库上使用归档日誌档案做恢复操作 。