`
阿尔萨斯
  • 浏览: 4169104 次
社区版块
存档分类
最新评论

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

 
阅读更多

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   http://blog.csdn.net/robinson_0612/article/details/9979405


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<3 order by first_time desc;  
                                                                                                                    
   SEQUENCE# FIRST_TIME          NEXT_TIME           APPLIED                                                       
  ---------- ------------------- ------------------- ---------------------------                                   
           7 2013/08/16 10:38:03 2013/08/16 10:46:11 YES                                                           
           6 2013/08/16 10:38:00 2013/08/16 10:38:03 YES                                                           


c、停用备库MRP进程
  对于将物理备库切换到逻辑备库,我们需要在主库构建LogMiner字典及启用补充日志,因此应先停用逻辑备库的MRP进程,避免产生额外的redo apply
  如果正在使用Broker管理现有的物理备库,应先在Broker中禁用目标数据库。

  HKBO> alter database recover managed standby database cancel;    


d、修改主库LOG_ARCHIVE_DEST_n参数
  对于将来需要将逻辑备库转为主库,而主库转为逻辑备库的情形,建议先修改LOG_ARCHIVE_DEST_n参数
  一是将主库LOG_ARCHIVE_DEST_1参数中的VALID_FOR属性改为仅仅联机重做日志有效,而不包括备用重做日志
  二是专门为备用重做日志添加一个新的归档路径,也就是说联机日志与备用日志分开,修改如下面的示例,此演示我们未做修改
  LOG_ARCHIVE_DEST_1=                                     --主库: cnbo  备库:hkbo
   'LOCATION=USE_DB_RECOVERY_FILE_DEST                    --当cnbo为主库时,用于存放cnbo产生的arch
    VALID_FOR=(ONLINE_LOGFILES,ALL_ROLES)                 --当cnbo被切换为备库角色后,用于存放自身作为备库产生的归档
    DB_UNIQUE_NAME=cnbo';

  LOG_ARCHIVE_DEST_3=                                     --此归档路径备用,仅当主库cnbo转换为备库是有效    
   'LOCATION=USE_DB_RECOVERY_FILE_DEST                    --当cnbo为备库角色时,用于存放从主库hkbo接收到的STANDBY_LOGFILES
    VALID_FOR=(STANDBY_LOGFILES,STANDBY_ROLE) 
    DB_UNIQUE_NAME=cnbo';
  LOG_ARCHIVE_DEST_STATE_3=ENABLE
  

d、主库上创建LogMiner数据字典
  CNBO> exec dbms_logstdby.build;


e、将物理备库转换为逻辑备库
  HKBO> show parameter db_name                        
  
  NAME                                 TYPE                              VALUE
  ------------------------------------ --------------------------------- ------------------------------
  db_name                              string                            cnbo
  
  HKBO> alter database recover to logical standby hkbo;
  
  --如果你使用了pfile文件,此处将ORA-16254,提示需要pfile文件的db_name
  
  HKBO> shutdown abort;
  HKBO> startup mount;     -->重启备库,因为逻辑备库更名,包括DBID、INCARNATION等均已被重新初始化
  HKBO> select name,database_role from v$database;
  
  NAME                        DATABASE_ROLE
  --------------------------- ------------------------------------------------
  HKBO                        LOGICAL STANDBY
  
  --Author : Robinson Cheng
  --Blog   : http://blog.csdn.net/robinson_0612


f、重建备库密码文件
  重建备库密码文件在Oracle 11g不再是必须的。在Oracle 10g中需要,且重建时要保持密码与主库相同


g、修改备库LOG_ARCHIVE_DEST_n参数
  与物理备库所不同的是,逻辑备库被open后会产生自己的重做日志(redo),因此我们需要配置参数LOG_ARCHIVE_DEST_n。
  对于逻辑备库,此时存在三种日志文件,即online redo log, archived redo log, standby redolog。
  HKBO> select name,value from v$parameter where name in ('log_archive_dest_1','log_archive_dest_2');
  
  NAME                      VALUE
  ------------------------- ------------------------------------------------------------
  log_archive_dest_1        LOCATION=USE_DB_RECOVERY_FILE_DEST db_unique_name=hkbo valid
                            _for=(ALL_LOGFILES,ALL_ROLES)
  
  log_archive_dest_2        SERVICE=cnbo ASYNC db_unique_name=cnbo valid_for=(ONLINE_LOG
                            FILES,PRIMARY_ROLES)
  
  HKBO> ho ls /u02/database/hkbo/fr_area/HKBO    -->这个是未修改之前的闪回区的文件夹
  archivelog  onlinelog
  
  HKBO> alter system set log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST 
    2  VALID_FOR=(ONLINE_LOGFILES, ALL_ROLES) DB_UNIQUE_NAME=hkbo';
  
  HKBO> alter system set log_archive_dest_3='LOCATION=USE_DB_RECOVERY_FILE_DEST
    2  VALID_FOR=(STANDBY_LOGFILES, STANDBY_ROLE) DB_UNIQUE_NAME=hkbo';
  
  HKBO> select name,value from v$parameter where name in ('log_archive_dest_1',
    2  'log_archive_dest_2','log_archive_dest_3');
  
  NAME                      VALUE                                            描述
  ------------------------- ------------------------------------------- ---------------------------
  log_archive_dest_1        LOCATION=USE_DB_RECOVERY_FILE_DEST          --当hkbo为备库时,存放备库产生的arch
                            VALID_FOR=(ONLINE_LOGFILES, ALL_ROLES)      --当hkbo转换成主库,存放作为主库的arch 
                            DB_UNIQUE_NAME=hkbo                        
  
  log_archive_dest_2        SERVICE=cnbo ASYNC db_unique_name=cnbo      --当hkbo为备库时,此参数被忽略
                            VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLES)   --当hkbo为主库时,传送redo data到备库cnbo
  
  log_archive_dest_3        LOCATION=USE_DB_RECOVERY_FILE_DEST          --当hkbo为备库时,直接归档从主库接收的standby log
                            VALID_FOR=(STANDBY_LOGFILES, STANDBY_ROLE)  --当hkbo转换为主库,此参数被忽略
                            DB_UNIQUE_NAME=hkbo

  --建议增加主库与备库的归档进程
  HKBO> alter system set log_archive_max_processes=9;
  CNBO> alter system set log_archive_max_processes=9;
  

h、打开逻辑备库
  --需要使用resetlog方式打开数据库  
  HKBO> alter database open resetlogs;  

  --对于同一主机上的逻辑备库,在首次启用SQL Apply之前需要执行下面的操作以便SQL跳过任意的ALTER TABLESPACE DDL
  --关于这个步骤是否是必须的,从Oracle Data Guard Concepts and Administration来看我的理解是要执行                          
  HKBO> exec dbms_logstdby.skip('ALTER TABLESPACE');
  

i、启用SQL Apply
  HKBO> alter database start logical standby apply immediate; 
  
  HKBO> ho ls /u02/database/hkbo/fr_area/HKBO  --多出了一个foreign_archivelog文件夹用于存放来自主库的日志
  archivelog  foreign_archivelog  onlinelog


j、校验结果
  CNBO> create user robin identified by xxx
    2   default tablespace users;
  
  CNBO> grant dba to robin;
  
  CNBO> conn robin/xxx;
  CNBO> create table t(what varchar(20),dt varchar(20));
  
  CNBO> insert into t select 'LogicalStdby',to_char(sysdate,'yyyymmdd hh24:mi:ss') from dual;
  
  CNBO> commit;
  
  CNBO> alter system switch logfile;
  
  HKBO> select * from robin.t;  --在备库上校验
  
  WHAT                   DT
  ---------------------- ---------------------------
  LogicalStdby           20130820 17:33:19


Oracle&nbsp;牛鹏社

更多参考

有关Oracle RAC请参考
使用crs_setperm修改RAC资源的所有者及权限
使用crs_profile管理RAC资源配置文件
RAC 数据库的启动与关闭
再说 Oracle RAC services
Services in Oracle Database 10g
Migrate datbase from single instance to Oracle RAC
Oracle RAC 连接到指定实例
Oracle RAC 负载均衡测试(结合服务器端与客户端)
Oracle RAC 服务器端连接负载均衡(Load Balance)
Oracle RAC 客户端连接负载均衡(Load Balance)
ORACLE RAC 下非缺省端口监听配置(listener.ora tnsnames.ora)
ORACLE RAC 监听配置 (listener.ora tnsnames.ora)
配置 RAC 负载均衡与故障转移
CRS-1006 , CRS-0215 故障一例
基于Linux (RHEL 5.5) 安装Oracle 10g RAC
使用 runcluvfy 校验Oracle RAC安装环境

有关Oracle 网络配置相关基础以及概念性的问题请参考:
配置非默认端口的动态服务注册
配置sqlnet.ora限制IP访问Oracle
Oracle 监听器日志配置与管理
设置 Oracle 监听器密码(LISTENER)
配置ORACLE 客户端连接到数据库

有关基于用户管理的备份和备份恢复的概念请参考
Oracle 冷备份
Oracle 热备份
Oracle 备份恢复概念
Oracle 实例恢复
Oracle 基于用户管理恢复的处理
SYSTEM 表空间管理及备份恢复
SYSAUX表空间管理及恢复
Oracle 基于备份控制文件的恢复(unsing backup controlfile)

有关RMAN的备份恢复与管理请参考
RMAN 概述及其体系结构
RMAN 配置、监控与管理
RMAN 备份详解
RMAN 还原与恢复
RMAN catalog 的创建和使用
基于catalog 创建RMAN存储脚本
基于catalog 的RMAN 备份与恢复
RMAN 备份路径困惑
使用RMAN实现异机备份恢复(WIN平台)
使用RMAN迁移文件系统数据库到ASM
linux 下RMAN备份shell脚本
使用RMAN迁移数据库到异机

有关ORACLE体系结构请参考
Oracle 表空间与数据文件
Oracle 密码文件
Oracle 参数文件
Oracle 联机重做日志文件(ONLINE LOG FILE)
Oracle 控制文件(CONTROLFILE)
Oracle 归档日志
Oracle 回滚(ROLLBACK)和撤销(UNDO)
Oracle 数据库实例启动关闭过程
Oracle 10g SGA 的自动化管理
Oracle 实例和Oracle数据库(Oracle体系结构)

分享到:
评论

相关推荐

    运用logical standby技术实现Oracle数据库的读写分离

    在MySQL作为应用系统的后台数据库时,我们常常见到这样的架构,一拖二、一拖三等等。这是用MySQL的读写分离技术,实现...我们这里介绍最后一个方法,利用dataguard技术中的logical standby实现Oracle数据库的读写分离。

    Oracle+Data+Guard+Linux+平台+Logical+Standby+创建实例

    DataGuard对于oracle初学者一直感觉是比较难的问题,看到这篇文章觉得不错,共享,大家一块学习

    Oracle 11g For Dummies.pdf

    Completely up to date for the newest release of Oracle, Oracle 11g For Dummies will give you both the information and the confidence to set up and maintain an Oracle database for your organization.

    Oracle 官方数据仓库资料

    Oracle 官方数据仓库指南,讲解透彻,知识权威,强烈推荐! Oracle® Database Data Warehousing Guide 10g Release 2 (10.2) Contents: Part I Concepts 1 Data Warehousing Concepts Part II Logical Design 2 ...

    《涂抹Oracle-三思笔记之一步步学Oracle》-李丙洋-源代码-6961.rar

    而logical目录中对应的是创建逻辑Standby时,Primary和Standby库中相关的配置文件; 目录13内文件为书中第13章出现的使用DataPump API实现导出的脚本; 目录14内文件为书中第14章,用来验证平台字节序的脚本; 目录...

    开源文档管理系统LogicalDOC v6.3.rar

    LogicalDOC是一个采用Java开发的基于网页的文档管理系统,提供了快速的索引功能和基于浏览器的查询功能。提供 .NET和PHP版本,附带论坛和WebDAV的接口,支持文档导入导出到ZIP文件和邮箱文件。 文件夹可分层次组织,...

    Oracle Core Essential Internals

    Since this book is only a couple of hundred pages and the 11g manuals extend to tens of thousands of pages it seems unlikely that I could possibly be describing “the whole thing ” so let me qualify...

    2010年10月最新ORACLE OCP培训教程

    Oracle Database 10g: “g” Stands for Grid 1-6 Oracle Database Architecture 1-8 Database Structures 1-9 Oracle Memory Structures 1-10 Process Structures 1-12 Oracle Instance Management 1-13 Server ...

    Oracle Concepts中英文对照版

    An Oracle database is a collection of data treated as a unit. The purpose of a database is to store and retrieve related information 数据库服务器是解决信息管理问题的核心组件。大体上说,数据库服务器 的...

    Oracle Essbase 11 Development Cookbook

    Table of Contents Preface Chapter 1: Understanding and Modifying Data Sources Chapter 2: Using Essbase Studio Chapter 3: Building the...http://www.packtpub.com/oracle-essbase-11-development-cookbook/book

    开源文档管理系统LogicalDOC v6.4.1

    LogicalDOC是一个采用Java开发的基于网页的文档管理系统,提供了快速的索引功能和基于浏览器的查询功能。易于使用和学习。它利用最佳的Java技术,实现了强大而灵活的解决方案。为用户提供了强大的搜索引擎(基于...

    logicaldoc-community-installer-8.3.4.zip

    为了提供可靠的DMS平台,LogicalDOC的设计基于最佳的Java技术。主界面是基于Web的,无需安装其他任何东西。用户可以通过其浏览器访问系统。 LogicalDOC CE是100%免费的软件,并与开源数据库打包在一起;尽管它支持...

    logicaldoc-community-installer-8.3.4.exe

    LogicalDOC文档管理-DMS 智能和开源文档管理系统 LogicalDOC是文档管理和协作系统。该软件具有许多功能,可以为任何组织和个人安全,安全地组织,索引,检索,控制和分发重要的业务文档。 公司使用纸质流程...

    fuzzy logical学习资料

    fuzzy logical很好的学习资料

    matlab开发-logical2cellstrcellstr2logical

    matlab开发-logical2cellstrcellstr2logical。从逻辑数组转换为字符串为“true”/“false”的单元格数组,然后再次进行转换。

    Logical Replication

    大多数人都知道Streaming Replication已经成为PostgreSQL的一部分,并且通常用于高可用性和读写分离,流复制是基于WAL日志的物理复制,适用于整个数据库实例的复制,并且备库是只读的。 Logical Replication属于...

    Database Logical

    database logical script

    Data.Modeling.Made.Simple.with.Embarcadero.ERStudio

    Data Modeling Made Simple with Embarcadero ER/Studio Data Architect: Adapting to Agile Data Modeling in a Big Data World Build a working knowledge of data modeling concepts and best practices, along ...

    shl logical

    shl logical

    Logical Channel Descriptor and Allocation of Logical Channel Numbers

    Logical Channel Descriptor and Allocation of Logical Channel Numbers

Global site tag (gtag.js) - Google Analytics