当前位置:  数据库>oracle

基于同一主机配置Oracle 11g Data Guard(logical standby)

    来源: 互联网  发布时间:2017-05-26

    本文导语: Oracle Data Guard逻辑备库是利用主库的一个备份首先建立一个物理备库,然后再将其转换为逻辑备库。这之后主库将日志传递到备库,备库利用logminer从主库的日志中解析出主库所执行过的SQL,在备库上重新执行一遍,从而保证与...

Oracle Data Guard逻辑备库是利用主库的一个备份首先建立一个物理备库,然后再将其转换为逻辑备库。这之后主库将日志传递到备库,备库利用logminer从主库的日志中解析出主库所执行过的SQL,在备库上重新执行一遍,从而保证与主库的数据在逻辑上保持一致。与物理备库相对应的是,物理备库使用的是redo apply,逻辑备库使用的是sql apply。因此逻辑备库仅仅保证数据与主库是在逻辑上是一致的,从而逻辑备库可以处于open状态下并进行相应的DML操作。本文描述了创建逻辑备库的注意事项以及给出了如何创建逻辑备库。

相关参考:
Oracle Data Guard 重要配置参数 
基于同一主机配置 Oracle 11g Data Guard   

1、逻辑备库的一些限制
对于逻辑备库,存在很多限制,如对于一些特殊的些数据类型象object,nested table,rowid,对象类型,自定义的数据类型等不被支持,以及不
支持段压缩,不支持一些特定的DDL语句等等一大堆的东西了。具体可以参考Oracle Data Guard Concepts and Administration。尽管如此,逻
辑备库依旧有很多物理备库所不具备的特点。下面仅仅列出逻辑备库几个重要关注的信息。

a、确定不被支持的schema
--对于Oracle数据库自带的相关schema会被跳过,因此不要基于这些schema来创建对象或测试,可使用下面的查询来查看
SQL> SELECT OWNER FROM DBA_LOGSTDBY_SKIP WHERE STATEMENT_OPT = 'INTERNAL SCHEMA';

b、确定不被支持的数据对象及数据类型
--使用下面的查询查找不被支持的表
SQL> SELECT DISTINCT owner, table_name FROM dba_logstdby_unsupported ORDER BY owner, table_name;

--可以对上面的查询结果进一步细化,来查找为什么表不被支持,如下查询是由于使用了object,nested table等类型导致该表不能被逻辑standby
SQL> SELECT column_name, data_type FROM dba_logstdby_unsupported WHERE owner = 'PM' AND table_name = 'PRINT_MEDIA';

COLUMN_NAME DATA_TYPE
------------------------------ -------------------------------------------
AD_TEXTDOCS_NTAB NESTED TABLE
AD_GRAPHIC BFILE
AD_HEADER OBJECT

c、确定存在唯一性问题的对象
由于逻辑standby与原数据库是逻辑相同,因此逻辑standby上的rowid并不等同于主库上的rowid。关于rowid可参考:Oracle ROWID
对于主库上的update,delete操作,Oracle通过主键和唯一索引/补充日志确保主库与备库所操作的对象为同一对象上的同一记录
对于启用了主键和唯一索引,补充日志的情形,每一条update语句如何去鉴别被更新的行呢?针对下面的情形在写redo的时候会附加列值唯一信息
表存在主键,则主键值会随同被更新列一起做为update语句的一部分
表无主键,存在非空的唯一索引/约束时,则最短的非空的唯一索引/约束会随同被更新列做为update语句的一部分
表无主键,无唯一索引/约束,所有可定长度的列(除long,lob,long raw,object type,collection类型列)连同被更新列作为update语句的一部分
注,存在函数唯一索引的表能够被实现SQL Apply,只要修改的行能够被唯一鉴别,但该索引函数不能用作唯一性去鉴别更新的行
对于那些可由应用程序确保表上的行记录唯一的,又不希望创建主键的情形,可以通过创建RELY约束,以避免维护主键所带来的额外开销
--可使用下面的方式为表添加RELY约束
SQL> ALTER TABLE tb_name ADD PRIMARY KEY (id, name) RELY DISABLE;

--数据字典DBA_LOGSTDBY_NOT_UNIQUE记录了那些不存在主键以及唯一索引的表或者是说没有足够的信息能够保证主库与逻辑standby锁定相同对象
SQL> SELECT owner, table_name FROM dba_logstdby_not_unique
2 WHERE (owner, table_name) NOT IN (SELECT DISTINCT owner, table_name FROM dba_logstdby_unsupported) AND bad_column = 'Y';

--查看主库是否启用补充日志,在主库执行包dbms_logstdby.build后即开始启用
SQL> select supplemental_log_data_pk,supplemental_log_data_ui from v$database;

2、逻辑备库的几个重要进程
逻辑备库需要一系列的进程来完成日志的捕获和应用工作。主要由两个组件组成:挖掘引擎与应用引擎。也就是一个负责从重归档日志或备用日
志提取SQL语句集,一个负责将其SQL语句集应用到逻辑备库。这两个引擎的相关进程可以通过V$LOGSTDBY_PROCESS视图中查询获得其相关信息。
挖掘引擎进程:
READER : 进程从主库传过来的归档或者standby redo logfile中解析重做记录(redo record)
PREPARER :进程负责将READER进程解析到的重做记录转换为LCR(Logical change record)
可以有多个PREPARER进程。解析出来的LCR存放在shared pool的一个叫做LCR cache的区域中
BUILDER :进程将LCR打包成事务,将多个LCR合成单个LCR,另外还负责管理LCR cache。如进行内存换页,推进日志挖掘检查点等

应用引擎进程:
ANALYZER :该进程负责检查一组LCR中包含的事务片段,过滤掉不需要应用的事务,检查不同事务的依赖关系等
COORDINATOR :该进程分配事务给APPLIER进程,监控事务依赖关系和协调提交顺序
APPLIER : 可以有多个该进程,它负责将LCR应用到备库

3、创建逻辑备库

a、首先创建物理备库
  创建物理备库的方法很多,对于Oracle 11g而言,可以直接从active database来创建,也可以基于10g 的RMAN使用duplicate方式来创建。
  关于物理备库的创建,此处不演示。
  可以参考:基于同一主机配置 Oracle 11g Data Guard 


b、 校验主库与物理备库
  --主库: CNBO,备库: HKBO
  --主库上的信息
  CNBO> select name,database_role,switchover_status from v$database;
 
  NAME              DATABASE_ROLE    SWITCHOVER_STATUS
  ----------------- ---------------- ------------------------
  CNBO              PRIMARY          TO STANDBY
 
  --备库上的信息
  HKBO> select name,open_mode,database_role,protection_mode from v$database;
 
  NAME      OPEN_MODE            DATABASE_ROLE    PROTECTION_MODE 
  --------- -------------------- ---------------- --------------------   
  HKBO      MOUNTED              PHYSICAL STANDBY MAXIMUM PERFORMANCE
 
  --SRL被apply的情形
  HKBO> select sequence#, first_time, next_time,applied from v$archived_log where rownum alter database recover managed standby database cancel;   


    
 
 

您可能感兴趣的文章:

  • linux 主机名配置问题
  • PHP配置文件应用(配置pdo与虚拟主机)
  • 动态主机配置协议管理 phpDHCPAdmin
  • apache虚拟主机的配置问题,急,高分
  • linux服务器主机名和ip配置
  • 怎样将我的linux系统配置成DMZ主机?
  • W7下宿主机与目标机配置问题
  • Vmware下装了Solaris,如何配置网络,使其与主机互访?
  • 主机换网卡了,里头的虚拟机怎么配置才能使用正常
  • 一个虚拟主机使用多个域名的配置方法(apache)该怎么写?
  • 虚拟机中的Linux该怎么配置和主机同在一个网段的IP啊
  • Apache中如何配置虚拟主机
  • 在配置了DNS并启动服务后,使用host命令察看主机,为什么会出现SERVFAIL的错误?
  • bobosji(波波司机)帮忙:weblogic配置好了虚拟主机,怎样使用?
  • LINUX作为客户机怎样配置才能连上学校的主机????
  • 怎样在tomcat 401上面配置一个虚拟主机?(更详细的提问)
  • apache 虚拟主机配置好了 为什么无法用域名访问
  • [X86] Solaris10配置网络的问题:宿主机上网使用了http代理
  • 虚拟主机中phpMyAdmin的安装配置方法
  • Linux主机下配置Oracle 10G自动启动过程记
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 主机访问桥接虚拟机web服务器失败,同网段其他主机可以访问
  • vmware虚拟机linux不能ping通主机,主机能ping通虚拟机
  • 我在windows下telnet到linux主机,想得到linux主机的一个文件该怎么办?
  • 更改主机名,用hostname更改后启动,又是原来的主机名
  • NOSQL iis7站长之家
  • 不同ip,相同主机名的unix系统会不会冲突?主机名用什么命令改?
  • 在linux下,如何访问另一台linux主机?如何访问windows主机?
  • 主机和虚拟机可以互相ping 通,主机可以上网,但是虚拟机ping不通外网!!!急急急
  • sftp实现两台主机之间传输文件(把一个主机中的文件拷贝到另一个)
  • 有没有办法编个叫本代替我登陆到自己的主机, 执行FTP命令下载另一个主机的文件?
  • unix 下 C++实现 ftp 到另一台主机上 修改文件内容 !能不能直接在主机上修改 还是只能get下来本地修改完后 在put上去
  • 为什么用new socket(主机名,端口号)的方法连接不上用serversocket(端口号)的主机
  • 虚拟主机Linux(Ubuntu9.10)连接主机 的路由器Or无限网卡上网方法
  • linux获取主机名后用gethostbyname() 不能获取主机ip
  • 怎样使两个主机的连通
  • scp远程两台主机时如何指定端口
  • rh9如何修改主机。
  • 主机ping不通虚拟机
  • hostname改变主机名
  • linux下主机名和域名如何设置


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,