検索
ホームページデータベースmysql チュートリアル基于同一主机配置Oracle 11g Data Guard(logical standby)

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                                                         

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
DockerでのMySQLメモリの使用を減らしますDockerでのMySQLメモリの使用を減らしますMar 04, 2025 pm 03:52 PM

この記事では、DockerのMySQLメモリ使用量を最適化することを調査します。 監視手法(Docker統計、パフォーマンススキーマ、外部ツール)および構成戦略について説明します。 これらには、Dockerメモリの制限、スワッピング、およびcgroupsが含まれます

mysqlの問題を解決する方法共有ライブラリを開くことができませんmysqlの問題を解決する方法共有ライブラリを開くことができませんMar 04, 2025 pm 04:01 PM

この記事では、MySQLの「共有ライブラリを開くことができない」エラーについて説明します。 この問題は、必要な共有ライブラリ(.so/.dllファイル)を見つけることができないMySQLの障害に起因しています。ソリューションには、システムのパッケージMを介してライブラリのインストールを確認することが含まれます。

Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?Mar 19, 2025 pm 03:51 PM

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)Mar 04, 2025 pm 03:54 PM

この記事では、PHPMyAdminの有無にかかわらず、LinuxにMySQLを直接インストールするのとPodmanコンテナを使用します。 それは、各方法のインストール手順を詳述し、孤立、携帯性、再現性におけるポッドマンの利点を強調しますが、

sqliteとは何ですか?包括的な概要sqliteとは何ですか?包括的な概要Mar 04, 2025 pm 03:55 PM

この記事では、自己完結型のサーバーレスリレーショナルデータベースであるSQLiteの包括的な概要を説明します。 SQLiteの利点(シンプルさ、移植性、使いやすさ)と短所(同時性の制限、スケーラビリティの課題)を詳しく説明しています。 c

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイドMACOSで複数のMySQLバージョンを実行する:ステップバイステップガイドMar 04, 2025 pm 03:49 PM

このガイドは、HomeBrewを使用してMacOSに複数のMySQLバージョンをインストールおよび管理することを示しています。 Homebrewを使用して設置を分離し、紛争を防ぐことを強調しています。 この記事では、インストール、開始/停止サービス、および最高のPRAを詳述しています

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?Mar 18, 2025 pm 12:01 PM

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか?人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか?Mar 21, 2025 pm 06:28 PM

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境