PlanetScale for Postgres は現在、早期アクセス版です。
サポート対象のPostgresバージョン
論理レプリケーションを有効にする
-
Postgresインスタンスでレプリケーションを有効にするには、まず次の設定になっていることを確認する必要があります。
確認するには、次のSQLコマンドを実行します。デフォルトでは、出力は
logicalになっているはずです。そうでない場合は、PlanetScale Console にログインし、Cluster configuration->Parametersに移動してWrite-ahead logまでスクロールし、設定を変更してください。
- また、設定
max_slot_wal_keep_sizeはデフォルトの4GBから増やすことを推奨します。これも PlanetScale Console でCluster configuration->Parametersに移動し、Write-ahead logまでスクロールして設定します。新しい値の決め方については、こちらを参照してください。
権限と publication を持つユーザーの作成
postgres.<...> ユーザーを使用して PlanetScale Postgres インスタンスに接続し、以下のコマンドを実行します。
-
ClickPipes 専用のユーザーを作成します。
-
前の手順で作成したユーザーに、スキーマレベルの読み取り専用アクセス権を付与します。以下の例は、
publicスキーマに対する権限を示しています。レプリケートしたいテーブルを含む各スキーマに対して、これらのコマンドを繰り返してください。 -
ユーザーにレプリケーション権限を付与します。
- レプリケートしたいテーブルを含む publication を作成します。パフォーマンス上のオーバーヘッドを避けるため、publication には必要なテーブルだけを含めることを強く推奨します。
-
特定のテーブルに対する publication を作成するには:
-
特定のスキーマ内のすべてのテーブルに対する publication を作成するには:
-
特定のスキーマ内のすべてのテーブルに対する publication を作成するには:
clickpipes publication には、指定したテーブルから生成される変更イベントのセットが含まれ、後でレプリケーションストリームの取り込みに使用されます。
注意事項
- PlanetScale Postgres に接続するには、現在のブランチを先ほど作成したユーザー名の末尾に追加する必要があります。たとえば、作成したユーザー名が
clickpipes_userの場合、ClickPipe の作成時に指定する実際のユーザー名はclickpipes_user.branchである必要があります。ここでbranchは、現在の PlanetScale Postgres ブランチの “id” を指します。これをすばやく確認するには、先ほどユーザー作成時に使用したpostgresユーザーのユーザー名を参照してください。ピリオド以降の部分がブランチ ID です。 - PlanetScale Postgres に接続する CDC パイプでは、
PSBouncerポート (現在は6432) を使用しないでください。通常のポート5432を使用する必要があります。初回ロードのみのパイプでは、どちらのポートも使用できます。 - 接続先は必ずプライマリ インスタンスのみにしてください。現在、レプリカ インスタンスへの接続はサポートされていません。