oracle data guard方案,Oracle Data Guard 概念篇

一个Data Guard 配置由一个生产库和一个或者多个standby数据库组成,在Data Guard配置中,主库和备库都既可以是rac环境,也可以是单机环境。

这篇文章主要介绍dataguard的一些基本知识

dataguard的分类、dataguard的服务类型、dataguard的保护模式

1.Dataguard中的备库分为物理备库和逻辑备库及快照备库

备库是主库的一致性拷贝,使用一个主库的备份可以创建多到30个备库,将其加入到dataguard环境中,创建成功后,dataguard通过自动应用从主库传送到备库的redo数据维护每个备库。

1.1物理备库(Physical standby database)

物理备库提供物理上和主数据库相同的拷贝,磁盘数据库结构和主库是相同的,物理备库是块到块的拷贝,一个物理备库通过应用从主库收到的redo数据保持和主库的同步,称为日志应用(redo apply),11g的dataguard在应用日志的时候是可以打开的,10g是不允许的。11g的这种特性称为active data guard。

1.2逻辑备库 (Logical standby database)

逻辑备库包含和主库相同的逻辑信息,物理结构和数据结构可以是不同的,逻辑备库把从主库收到的redo转换为sql语句,然后在备库上执行sql语句,称为sql应用(sql apply)。逻辑备库除了能应用于灾难恢复,还允许用户查询逻辑备库和通过逻辑备库生成报表,用于其他目的,使用逻辑备库能升级database软件,在无停机的情况下打补丁等操作。

1.3快照备库 (Snapshot Standby Database)

快照备库是11g中出现的,类似物理备库和逻辑备库一样,快照备库从主库接收redo数据,和物理或逻辑备库不同的是,快照备库只接收而不应用接收到的redo数据。直至快照备库转换为物理备库,之后先扔掉任何对快照备库的更新,然后应用接收到的redo数据。快照数据库最好用在要求临时的,可更新的物理备库快照场景。

典型的data guard配置如图所示,来自oracle concept

7b7211aa010eaf5183312d05e92cff39.png

2. dataguard的服务类型 (Data GuardServices)

日志传输服务(Redo Transport Services)

日志应用服务(Apply Services)

角色转换     (Role Transitions)

2.1日志传送服务管理从生产库传送redo数据到一个或多个归档目录。日志传输服务完成以下工作:

2.1.1在配置中从主库传输redo数据到备库

2.1.2在网络失败后,管理备库缺失的archivelog,自动解决缺失

2.1.3自动扫描在备库中错误的或损坏的redo,自动从主库或其他备库重新获得并替换损坏的archive log。

log_archive_dest_n初始化参数用来确定本地的redo和远程归档redo的位置。log_archive_dest_n中详细参数解析

2.2日志应用服务在备库中应用redo数据,维护和备库主库之间的同步,redo数据默认从归档redo日志中应用,若启用了实时应用,则直接从standby redo日志中应用;对于非实时应用redo,当主库日志发生切换时,备库才会应用从主库传输来的redo日志。默认情况下,对于非实时应用,应用服务会等待备库redo日志被归档才会应用归档redo日志,实时应用允许应用服务应用当前正在填充的备库redo日志中的redo数据。

日志应用工作方式:redo apply和sql apply

物理备库和逻辑备库主要的区别就是日志应用的工作方式不同,物理备库使用redo apply,逻辑备库使用sql apply,类似MySQL 的主从的方式。

Redo apply在物理备库上使用常规的数据库恢复技术,也就是介质恢复,来应用redo中的数据。如图所示:

23e3c26258d5e4768fc3729dd129a1a9.png

Sql apply在逻辑备库上使用这种方式,首先将接收到的redo数据转换为sql语句,然后在逻辑备库中执行生成的sql语句,之后在备库中应用。使用的是logminer技术。如图

2ad120973a2a5ceff53a8d7a7536c0d7.png

日志应用服务配置

standby redolog

实时应用要求standby数据库必须有standby redo日志,lgwr同步和异步传输模式要求传输目的地配置standby redo日志,standby redo日志用于存储从一个主库接收到的redo日志,standby redo日志在结构上和联机redo日志是相同的,也使用创建和管理联机redo日志相同的sql来创建和管理standbyredo日志。

Standby数据库使用RFS前台进程接收传送过来的redo日志,将其写到当前的standby redo日志组,当源数据库发生了日志切换,传入的redo将写到下一个standby redo日志组中,之前的standby 日志通过ARCn前台进程被归档。在源数据库,进程顺序地填充和归档redo日志组,这种方式呗镜像到每个redo传输目的地,在standby数据库以相同的顺序填充和归档standby redo日志组。

每个standby redo日志的大小必须至少和redo源数据库的redo日志组中最大的redo日志一样大,推荐传输目的地的standby redo日志和源主库的redo日志中的所有日志相同大。

对于standby 数据库的每个redo线程,standby redo日志至少比在redo源主库的redo日志多一个redo日志组,在源主库,查询v$log视图确定源主库redo日志组的个数,对于rac,查询v$thread视图确定源主库redo的线程数,对每个线程使用的standby redo日志进行配置。

操作过程:

selectgroup#,bytes from v$Log ;主库

selectgroup#,bytes from v$standby_log ;备库

Oracle推荐在dataguard中的主数据库也创建standby redo日志,这样当switchover到备库角色也可以立即实现实时接收redo数据

alterdatabase add standby logfile创建或添加standby redo日志,如果standby redo日志租不活动或者redo传输用于解决缺失,那么standby数据库接收到的redo数据被直接写到一个归档redo日志。

实时应用redo 数据

若启用实时应用特性,应用服务能在不等待当前standby redo数据被归档的情况下,应用接收到的redo数据,这样使得switchover和failover的速度更快,因为standby redo日志中的数据在failover或者switchover开始的时候已经被应用到standby 数据库,减少了切换需要花费的时间。

物理备库开启实时引用

alterdatabase recover managed standby database using curren logfile dixconnect fromsession ;

逻辑备库开启实时引用

alterdatabase start logical standby apply immediate ;

启用实时应用要求备库配置由standby redo日志,并且开启了归档

注:对于日志传输,可以将其划分为实时传输(同步、异步)和切换时传输(默认传输方式),实时传输与实时应用之间没有关系,实时传输只是和dataguard保护模式有关。

延迟应用redo

在一定程度上保护应用程序对主库的破坏及减少误操作对standby数据库的影响。当设置delay间隔之后,不能延迟传输redo数据到standby数据库,只是会延迟应用redo日志,从standby目的地完成归档开始计算延迟时间。延迟结束之后开始应用归档日志。

指定延迟时间:

在主库和备库通过指定log_archive_dest_n初始化参数delay=设置延迟时间,默认情况是没有延迟时间的,若指定了delay参数但是没有指定值,默认是30分钟。

取消指定时间

物理备库

alterdatabase recover managed standby database nodelay ;

逻辑备库

alterdatabase start logical standby apply nodelay;

执行以上的命令,在时间间隔到之前应用服务立即开始应用归档redo日志文件到备库。

2.3使用switch over或failover操作改变数据库角色,将备库转换成主库或将主库转换为备库。

Switchover是主库个一个备库的转换,可以确保没有数据丢失,是在有计划的典型操作。在switchover期间,主库角色转变为备库,备库转换为主库,在主库inactive时,failover可以将备库转换为主库角色,failover可能会导致数据丢失,failover只有在主数据库启动失败的情况下才使用。

3.dataguard的保护模式

Oracle提供三种保护模式满足不同级别的系统。最大保护、最大性能、最高可用。三种保护模式都要求使用特定的redo传送选项发送redo数据到至少一个备库

3.1最大保护

如果主库失败,最大保护模式可以确保没有数据丢失,事务在完成提交之前,事务恢复需要的redo数据必须写到主库的联机redo日志和至少一个同步的备库的standby redo log,若主库不能写redo数据到至少一个备库,为了确保数据不会丢失,主库会被关闭,正是应了最大保护模式这句话。

使用最大保护模式必须符合的条件:

a.主库在log_archive_dest_n的参数设置中必须使用到lgwr sync affirm属性来归档到备库

b.备库必须配置standby redo log

c.至少有一个备库是可用的

采用最大保护模式的主库,不能使用shutdown immediate对唯一的standby数据库执行关闭操作。因为会导致主库关闭

3.2最大性能

是默认的保护模式,提供在不影响主库性能的情况下的最高级别的数据库保护模式,主库的用户事务一旦被写入本地联机redo中,就被允许提交,不需要立刻写到至少一个备库中,主库只要使用arch 或lgwr async属性对远程的备库进行归档即可,redo数据也写到一个或多个备库,但是对于事务提交是异步完成的,因此通过延迟写redo数据到备库不会影响主库的性能,这种保护模式提供您比最高可用模式较少的保护,但是能最低程度的影响主库的性能

3.3最高可用

采用个最大保护模式同样的方式,确保redo日志被完全写入本地数据库和至少一个备库的standby redo log中,才会给用于返回提交完成的信息,若因为某些原因导致备库不可用,主库不能讲redo写入到备库的standby redo 中,此时主库并不会关闭,主库将暂时将保护模式降为最大性能模式,并且继续进行工作,一旦备库恢复正常,主库的缺失消除方案会启动,归档redo日志的缺失部分会被填满,当主库下一个日志打开的时候,主库中的保护模式又会上升为最高可用。采用最高可用必须满足的条件:

a.主库在log_archive_dest_n初始化参数中需要使用lgwr sync affirm属性归档到备库

b.备库必须配置standby redo log

c.至少有一个备库处于可用状态

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/537851.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

洛谷P4133 [BJOI2012]最多的方案(记忆化搜索)

题意 题目链接 求出把$n$分解为斐波那契数的方案数&#xff0c;方案两两不同的定义是分解出来的数不完全相同 Sol 这种题&#xff0c;直接爆搜啊。。。 打表后不难发现$<1e18$的fib数只有88个 最先想到的应该是直接把$n$加入到搜索状态里&#xff0c;然后枚举能被分成哪些 但…

大话php设计模式视频,大话PHP设计模式

工厂模式用工厂方法或者类来实例化对象&#xff0c;而不是直接new。首先我们需要创建一个工厂类&#xff0c;比如Factory.php。如果不使用工厂模式的&#xff0c;我们需要一个对象的时候通常需要new Inexistence\girlfriend();然而我们一般不只在一个地方需要这个对象&#xff…

美团点评基于MGR的CMDB高可用架构搭建之路【转】

王志朋 美团点评DBA 曾在京东金融担任DBA&#xff0c;目前就职于美团点评&#xff0c;主要负责金融业务线数据库及基础组件数据库的运维。 MySQL Group Replication&#xff08;以下简称MGR&#xff09;&#xff0c;于5.7.17版本正式GA&#xff0c;由Oracle官方出品&#xff0c…

redmine更换主题

主题列表&#xff1a;http://www.redmine.org/projects/redmine/wiki/Theme_List 虽然有很多主题&#xff0c;但是很多主题都是要钱的&#xff0c;像这类&#xff08;上图&#xff09;没有下载地址的&#xff0c;都是要钱的。 含GitHub的下载地址的&#xff0c;是免费可下载的&…

redmine 邮箱配置(阿里云+windows)

说明 密码是第三方的授权码&#xff0c;不是邮箱密码 需要登录126网页版&#xff0c;在设置里开启 smtp 等第三方服务&#xff0c;设置授权码 阿里云Linux 默认屏蔽25号端口&#xff0c;所以需要开启ssl&#xff0c;和使用 465 端口 重启下 redmind sh /opt/redmine-3.4.6-…

linux查看当前用户终端,Linux----基本命令的使用(vi命令,查看文件内容,显示进程,切换用户等)...

1、vi是linux系统上经常使用的一个文本编辑器&#xff0c;其有三种模式&#xff1a;命令模式、编辑模式(插入模式)、末行模式。命令模式——>编辑模式&#xff1a;“i a o I A O”linux编辑模式——>命令模式&#xff1a;“ESC”shell命令模式——>末行模式&#xff1…

centos6.8 环境一键安装包 nginx配置thinkphp5

---恢复内容开始--- lnmp1.4 一键安装包 nginx配置thinkphp5 环境&#xff1a;Nginx1.12.1 PHP5.6 Coentos6.8 修改网站配置文件 server{listen 443 ssl http2;#listen [::]:443 ssl http2;server_name xxx.cn;index index.html index.htm index.php default.html default.ht…

Linux下BitNami Redmine的插件安装与更新

截至2017年3月27日&#xff0c;Redmine-3.3.2-2安装以下的15款插件全部成功并通过测试&#xff08;下面显示为插件正确文件夹名&#xff09;&#xff1a; easy_wbs redmine_ckeditor 提供所见即所得编辑器 redmine_graphs 提供部分问题图表功能 progressive_projects_list 是…

Linux下redmine安装插件报错

报错如下&#xff1a; There was an error parsing Gemfile: compile error - syntax error, unexpected :, expecting $end gem tzinfo-data, platforms: [:mingw, :x64_mingw, :mswin, :jruby]^. Bundler cannot continue. 原因是&#xff1a; redmine不同版本对ruby版本有…

linux限制ping的时间,如何限制Linux命令程序运行的时间

Linux提供了大量的命令&#xff0c;每个命令都是唯一的&#xff0c;并且在特定的情况下使用。Linux的目标是帮助您尽可能地高效工作。Linux命令的一个属性是时间限制。您可以为任何您想要的命令设置时间限制。如果时间过期&#xff0c;命令停止执行。在本教程中&#xff0c;您将…

微软网络工具psping介绍

该工具功能主要包括&#xff1a;ICMP Ping、TCP Ping、延迟测试、带宽测试&#xff0c;而且它是微软出品的下载地址&#xff1a;https://download.sysinternals.com/files/PSTools.ziphttp://technet.microsoft.com/en-us/sysinternals/jj729731解压后把psping.exe丢到C:\Windo…

mac svn

https://formac.informer.com/tortoisesvn

linux无法下载ftp,linux 不能下载怎么办

linux 不能下载怎么办&#xff1f;关于Linux下vsftp匿名用户上传和下载的配置配置要注意三部分&#xff0c;请一一仔细对照&#xff1a;1、vsftpd.conf文件的配置(vi /etc/vsftpd/vsftpd.conf)&#xff03;允许匿名用户登录FTPanonymous_enableYES&#xff03;设置匿名用户的登…

Spring IOC实现原理

2019独角兽企业重金招聘Python工程师标准>>> 1、BeanDefinition 对依赖翻转模式中管理对象依赖关系的数据抽象 实现依赖翻转功能的核心数据结构依赖翻转功能都是围绕对BeanDefinition 处理完成的有了这些BeanDefinition 基础数据结构&#xff0c;容器才能发挥作用2、…

openlayers入门开发系列之图层控制

本篇的重点内容是利用openlayers实现地图图层控制功能&#xff0c;效果图如下&#xff1a; 部分核心代码如下&#xff1a;页面引用ztree插件图层管理器界面布局图层管理器初始化jsLayerSwitcher类定义详细的实现过程见&#xff1a;这里

windows版本的redis

redis官网是不提供windows版本的。 微软的github上有windows版本下载&#xff0c;不会是redis的最新版本&#xff0c;是基于redis稳定版本制作的。 redis官网关于文档版本的说明&#xff1a; Redis uses a standard practice for its versioning: major.minor.patchlevel. A…

一点一点看JDK源码(五)java.util.ArrayList 后篇之removeIf与Predicate

一点一点看JDK源码&#xff08;五&#xff09;java.util.ArrayList 后篇之removeIf与Predicate liuyuhang原创&#xff0c;未经允许禁止转载 本文举例使用的是JDK8的API 目录&#xff1a;一点一点看JDK源码&#xff08;〇&#xff09; Predicate为jdk1.8新增接口&#xff0c;由…

使用nginx代理,怎么获取真实的IP

1.在nginx.conf配置中加入配置信息 proxy_set_header Host $http_host;proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-NginX-Proxy true; 2.然后…

catcti监控linux主机,CentOS7搭建Prometheus 监控Linux主机

简介prometheus可以拆分成多个节点进行指标收集。安装prometheuswget -c https://github.com/prometheus/prometheus/releases/download/v2.23.0/prometheus-2.23.0.linux-amd64.tar.gztar zxvf prometheus-2.23.0.linux-amd64.tar.gz -C /opt/cd /opt/ln -s prometheus-2.23.…

linux 安装redis2.8.3,Linux及Windows安装Redis(详细)

标签&#xff1a;Linux及Windows安装Redis1.Windows安装教程1.1下载https://github.com/MSOpenTech/redis/releases进入github里下载redis Windows版压缩包将我们下载好的文件放进新建的一个Redis文件夹(我在C盘创建了一个redis的文件夹)1.2启动服务打开我们Windows版的dos命令…