> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-mintlify-8a08bda2.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# 読み取りレプリカ

> ClickHouse Managed Postgres の読み取りレプリカを使用して、読み取り負荷の高いワークロードをスケール

export const Image = ({img, alt, size}) => {
  return <Frame>
      <img src={img} alt={alt} />
    </Frame>;
};

export const galaxyOnClick = eventName => () => {
  try {
    if (typeof window !== "undefined" && window.galaxy && eventName) {
      window.galaxy.track(eventName, {
        interaction: "click"
      });
    }
  } catch (e) {}
};

export const BetaBadge = ({link, galaxyTrack, galaxyEvent}) => {
  if (link) {
    return <a href={link} target="_blank" rel="noopener noreferrer" className="betaBadge" onClick={galaxyTrack && galaxyEvent ? galaxyOnClick(galaxyEvent) : undefined}>
                <Icon />
                <span>Beta</span>
            </a>;
  }
  return <div className="betaBadge">
            <Icon />
            <span>
                Beta feature. 
                <u>
                    <a href="/docs/beta-and-experimental-features#beta-features">
                        Learn more.
                    </a>
                </u>
            </span>
        </div>;
};

読み取りレプリカを使用すると、プライマリの Managed Postgres データベースのコピーを 1 つ以上作成できます。これらのレプリカは、PostgreSQL のネイティブなレプリケーションを使用してプライマリ データベースに継続的に追従し、変更内容を常に反映します。

読み取りレプリカを管理するには、warehouse の編集アイコンをクリックします。

<Image img="https://mintcdn.com/private-7c7dfe99-mintlify-8a08bda2/1Ag2q2dX2WMxuS9G/images/managed-postgres/warehouse-view.png?fit=max&auto=format&n=1Ag2q2dX2WMxuS9G&q=85&s=568e88556a5b4fd0c5059f87534bcee4" alt="編集アイコンが表示された warehouse ビュー" size="md" border width="2490" height="750" data-path="images/managed-postgres/warehouse-view.png" />

これにより warehouse ダイアログが開き、既存のサービスを確認したり、新しい読み取りレプリカを作成したりできます。

<Image img="https://mintcdn.com/private-7c7dfe99-mintlify-8a08bda2/1Ag2q2dX2WMxuS9G/images/managed-postgres/read-replica-dialog.png?fit=max&auto=format&n=1Ag2q2dX2WMxuS9G&q=85&s=2ef375497d69d131b38f2b51a105b4f0" alt="読み取りレプリカ管理ダイアログ" size="md" border width="1370" height="870" data-path="images/managed-postgres/read-replica-dialog.png" />

<div id="managing-read-replicas">
  ## 読み取りレプリカの管理
</div>

**Read replicas** ページでは、右上の **Flow** と **Table** のコントロールで切り替えられる 2 つのビューを利用できます。

**Flow** ビューにはレプリケーションのトポロジーが表示されます。上部にプライマリ インスタンスがあり、そこから各レプリカへ下向きの矢印で接続され、ティア、リージョン、ステータスをひと目で確認できます。

<Image img="https://mintcdn.com/private-7c7dfe99-mintlify-8a08bda2/1Ag2q2dX2WMxuS9G/images/managed-postgres/read-replicas-flow.png?fit=max&auto=format&n=1Ag2q2dX2WMxuS9G&q=85&s=8147e8db82a44837680596fb29a62606" alt="プライマリとレプリカのトポロジーを示す読み取りレプリカのフロービュー" size="lg" border width="1556" height="682" data-path="images/managed-postgres/read-replicas-flow.png" />

**Table** ビューには、各レプリカのサービス名、クラウドプロバイダーとリージョン、サービスのステータス、作成時刻、そして **Detach service** アクションが一覧表示されます。

<Image img="https://mintcdn.com/private-7c7dfe99-mintlify-8a08bda2/1Ag2q2dX2WMxuS9G/images/managed-postgres/read-replicas-table.png?fit=max&auto=format&n=1Ag2q2dX2WMxuS9G&q=85&s=01f28a13a3aae9f8e92a5c5f6461411e" alt="読み取りレプリカのテーブルビュー" size="lg" border width="1556" height="392" data-path="images/managed-postgres/read-replicas-table.png" />

新しいレプリカを作成するには、いずれかのビューの右上にある **Create read replica** をクリックします。

<div id="why-use-read-replicas">
  ## 読み取りレプリカを使用する理由
</div>

<div id="scalability">
  ### スケーラビリティ
</div>

読み取りレプリカを使用すると、読み取り負荷の高いワークロードを複数の専用インスタンスに分散し、データベースを水平方向にスケールできます。これは、レポート用クエリ、分析処理、リアルタイムダッシュボードが本番トラフィックとリソースを奪い合うのを防ぐうえで、特に有効です。

<div id="isolation">
  ### 分離
</div>

分析クエリやビジネスインテリジェンス向けのクエリを読み取りレプリカに振り分けることで、プライマリインスタンスは書き込み処理や重要なトランザクション処理に専念でき、高い応答性を維持できます。この分離により、システム全体のパフォーマンスと予測可能性が向上します。また、分析ツールやレポートツールに書き込み権限を付与する必要もありません。これらのツールはレプリカに対して安全に利用できるため、誤ってデータを変更してしまうリスクもありません。

<div id="business-continuity">
  ### 事業継続
</div>

読み取りレプリカは、災害復旧において重要な役割を果たします。プライマリデータベースで障害が発生した場合は、読み取りレプリカをプライマリに昇格させることで、ダウンタイムとデータ損失を最小限に抑えられます。これにより、高可用性スタンバイに加えて、さらなる耐障害性を確保できます。

<div id="how-read-replicas-work">
  ## 読み取りレプリカの仕組み
</div>

Managed Postgres の読み取りレプリカでは、ストリーミングレプリケーションではなく、WAL shipping アーキテクチャを採用しています。この設計は、プライマリデータベースへの影響を最小限に抑えることを重視したものです。

<div id="wal-shipping-from-object-storage">
  ### オブジェクトストレージを使用した WAL shipping
</div>

プライマリデータベースがトランザクションを処理すると、Write-Ahead Log (WAL) レコードが生成されます。これらの WAL セグメントは継続的にオブジェクトストレージ (S3) にアーカイブされます。読み取りレプリカは、プライマリとの同期を維持するため、オブジェクトストレージからこれらの WAL セグメントを取得して再生します。

このアーキテクチャは、プライマリへの直接接続を使用するストリーミングレプリケーションを利用する[高可用性スタンバイ](/ja/products/managed-postgres/high-availability)とは異なります。

<div id="why-we-chose-this-approach">
  ### このアプローチを採用した理由
</div>

私たちは、読み取りレプリカがストリーミングスタンバイとしてプライマリに直接接続するのではなく、オブジェクトストレージから WAL を読み取るよう意図的に設計しました。このアプローチにより、読み取りレプリカとプライマリデータベースを完全に分離できます。

* **プライマリでのレプリケーションのオーバーヘッドはゼロ**: 読み取りレプリカはプライマリへのストリーミング接続を維持しないため、ミッションクリティカルなワークロードに CPU、メモリ、ネットワークの負荷を一切追加しません。
* **独立したスケーリング**: プライマリのパフォーマンスにまったく影響を与えることなく、読み取りレプリカを追加または削除できます。
* **ネットワーク分離**: 読み取りレプリカは、接続先エンドポイントが分離された独自のネットワーク環境で動作します。

<div id="replication-lag-characteristics">
  ### レプリケーションラグの特性
</div>

このアーキテクチャにおけるトレードオフは、レプリケーションラグです。WAL セグメントは一定間隔でプライマリからアーカイブされます (通常は 60 秒ごと、またはセグメントがいっぱいになった時点のいずれか早い方) 。そのため、通常の条件では、読み取りレプリカがプライマリに対して最大で数十秒遅れる可能性があります。

レポート、分析、ダッシュボードといった、ほとんどの読み取りスケーリングのユースケースでは、この遅延は許容範囲です。アプリケーションでほぼリアルタイムの読み取りが必要な場合は、クエリをプライマリに送れるか、またはこの時間内での結果整合性が要件を満たすかを検討してください。
