他のバージョンの文書 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9.6 | 9.5 | 9.4 | 9.3 | 9.2 | 9.1 | 9.0 | 8.4 | 8.3 | 8.2 | 8.1 | 8.0 | 7.4 | 7.3 | 7.2

第29章 論理レプリケーション

目次

29.1. パブリケーション
29.1.1. レプリカアイデンティティ
29.2. サブスクリプション
29.2.1. レプリケーションスロットの管理
29.2.2. 例: 論理レプリケーションの設定
29.2.3. 例: レプリケーションスロットの遅延作成
29.3. 論理レプリケーションのフェイルオーバー
29.4. 行フィルタ
29.4.1. 行フィルタルール
29.4.2. 式の制限
29.4.3. UPDATE変換
29.4.4. パーティション化テーブル
29.4.5. 初期データ同期
29.4.6. 複数行フィルタの統合
29.4.7. 例
29.5. 列リスト
29.5.1. 例
29.6. 生成列のレプリケーション
29.7. コンフリクト
29.8. 制限事項
29.9. アーキテクチャ
29.9.1. 初期スナップショット
29.10. 監視
29.11. セキュリティ
29.12. 構成設定
29.12.1. パブリッシャー
29.12.2. サブスクライバー
29.13. アップグレード
29.13.1. パブリッシャーのアップグレードの準備
29.13.2. サブスクライバーのアップグレードの準備
29.13.3. 論理レプリケーションクラスタのアップグレード
29.14. 簡単な設定

論理レプリケーションとは、レプリケーションアイデンティティ(replication identity)(通常は主キーです)に基づき、データオブジェクトと、それに対する変更を複製する手法です。 この論理という用語は、正確なブロックアドレスを使い、バイト同士の複製を行う物理レプリケーションと対比的に使用しています。 PostgreSQLは両方の仕組みを同時にサポートします。 第26章をご覧ください。 論理レプリケーションにより、データの複製とセキュリティに対するきめの細かい制御が可能になります。

論理レプリケーションは、ひとつのパブリッシャー(publisher)ノード上の一つ以上のパブリケーション(publications)を購読する一つ以上のサブスクライバー(subscribers)を伴う、パブリッシュ(publish)サブスクライブ(subscribe)モデルを使用します。 サブスクライバーは、サブスクライブするパブリケーションからデータを取得し、再パブリッシュしてカスケードレプリケーションや、更に複雑な構成を構築することができます。

通常、テーブルの論理レプリケーションが開始されると、PostgreSQLはパブリッシャーデータベースのテーブルデータのスナップショットを取得し、それをサブスクライバーにコピーします。 完了すると、最初のコピー以降のパブリッシャーの変更がサブスクライバーに継続的に送られます。 パブリッシャーと同じ順序でデータを適用するため、一つのサブスクリプション内のパブリケーションに対するトランザクションの一貫性が保証されます。 この方式によるデータレプリケーションは、トランザクショナルレプリケーション(transactional replication)と呼ばれることがあります。

典型的な論理レプリケーションの利用例には、以下のようなものがあります。

サブスクライバーのデータベースは、他のPostgreSQLインスタンスと同様に振る舞い、自分用のパブリケーションを定義することにより、他のデータベースに対するパブリッシャーとして利用できます。 アプリケーションがそのサブスクライバーを読み取り専用として取り扱うときには、単独のサブスクリプションからはコンフリクトは発生しません。 一方、アプリケーションあるいは他のサブスクライバーから同じテーブルに書き込みが起こるとすると、コンフリクトが発生する可能性があります。