Oracle Data Guard逻辑备库是利用主库的一个备份首先建立一个物理备库,然后再将其转换为逻辑备库。这之后主库将日志传递到备库,
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';
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
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

mySqlStringTypesimpactStorageAndPerformanCeaseAsfollows:1)长度,始终使用theSamestoragespace,whatcanbefasterbutlessspace-felfficity.2)varCharisvariable varcharisvariable length,morespace-morespace-morespace-effficitybuteftife buteftife butfority butfority textifforlyslower.3)

mySqlStringTypesIncludeVarChar,文本,char,enum和set.1)varCharisVersAtileForvariable-lengthStringStringSuptOptoPeptoPepecifientlimit.2)textisidealforlargetStortStorStoverStorextorewiteWithoutAdefinedLengthl.3)charlisfixed-Length

MySQLoffersvariousstringdatatypes:1)CHARforfixed-lengthstrings,2)VARCHARforvariable-lengthtext,3)BINARYandVARBINARYforbinarydata,4)BLOBandTEXTforlargedata,and5)ENUMandSETforcontrolledinput.Eachtypehasspecificusesandperformancecharacteristics,sochoose

TograntpermissionstonewMySQLusers,followthesesteps:1)AccessMySQLasauserwithsufficientprivileges,2)CreateanewuserwiththeCREATEUSERcommand,3)UsetheGRANTcommandtospecifypermissionslikeSELECT,INSERT,UPDATE,orALLPRIVILEGESonspecificdatabasesortables,and4)

toadduserInmysqleffectection andsecrely,theTheSepsps:1)USEtheCreateuserStattoDaneWuser,指定thehostandastrongpassword.2)GrantNectalRevileSaryPrivilegesSustate,usiveleanttatement,AdheringTotheTeprinciplelastPrevilegege.3)

toaddanewuserwithcomplexpermissionsinmysql,loldtheSesteps:1)创建eTheEserWithCreateuser'newuser'newuser'@''localhost'Indedify'pa ssword';。2)GrantreadAccesstoalltablesin'mydatabase'withGrantSelectOnMyDatabase.to'newuser'@'localhost';。3)GrantWriteAccessto'

MySQL中的字符串数据类型包括CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT,排序规则(Collations)决定了字符串的比较和排序方式。1.CHAR适合固定长度字符串,VARCHAR适合可变长度字符串。2.BINARY和VARBINARY用于二进制数据,BLOB和TEXT用于大对象数据。3.排序规则如utf8mb4_unicode_ci忽略大小写,适合用户名;utf8mb4_bin区分大小写,适合需要精确比较的字段。

最佳的MySQLVARCHAR列长度选择应基于数据分析、考虑未来增长、评估性能影响及字符集需求。1)分析数据以确定典型长度;2)预留未来扩展空间;3)注意大长度对性能的影响;4)考虑字符集对存储的影响。通过这些步骤,可以优化数据库的效率和扩展性。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

Dreamweaver CS6
视觉化网页开发工具