TDE 対応クラスタを作成する

ドキュメントのバージョンを選択します。

始める前に

クラスタを作成する

TDE 対応クラスタを作成するには、データベースの初期化時に必要な Key Management Service(KMS)の構成と認証情報を渡す必要があります。サポートされている認証タイプは jwt のみです。

  1. RPM を使用して AlloyDB Omni をインストール し、環境を準備して AlloyDB Omni RPM パッケージをインストールします。

  2. データベースを初期化します。

    HashiCorp Vault KMS

    この方法は、本番環境ワークロードに使用します。

    1. 次のコマンドを実行して、TDE を有効にしてデータベースを初期化します。

      sudo PGPASSWORD=POSTGRES_PASSWORD \
      PGDATA=DATA_DIR \
      VAULT_AUTH_TYPE=jwt \
      VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \
      VAULT_JWT_PATH=JWT_FILE_PATH \
      VAULT_ROLE=VAULT_ROLE \
      VAULT_CERT_PATH=VAULT_CERT_PATH \
      POSTGRES_INITDB_ARGS="--tde-kek-url=KEK_URL" \
      /usr/lib/postgresql/18/bin/alloydbomni18-setup initdb

      次のように置き換えます。

      • POSTGRES_PASSWORD: データベース ユーザーのパスワード。
      • DATA_DIR: AlloyDB Omni のデータボリュームとしてマウントするローカル ディレクトリ(例: /local/data)。
      • VAULT_AUTH_TYPE: Vault 接続に使用する認証のタイプ。jwt のみがサポートされています。
      • JWT_AUTH_ENGINE_MOUNT: HashiCorp Vault 認証エンジンがマウントされているパス(例: /auth/jwt)。
      • JWT_FILE_PATH: ノードに Vault JWT が保存されているパス(例: tde-tls/jwt-token)。
      • (省略可)VAULT_ROLE: Vault の設定で定義されたクライアント ロール。HashiCorp Vault はこのロールを使用して JWT トークンの信頼性を検証します。
      • VAULT_CERT_PATH: Vault 接続の証明書がコンテナに配置されているパス(例: /tde-tls)。設定されていない場合は、デフォルトのトラストストアの証明書が使用されます。
      • KEK_URL: HashiCorp Vault の KEK の完全修飾 URL。KMS プロバイダとして HashiCorp Vault を指定するには、プロトコルとして vault を使用します(例: vault://127.0.0.1:8200/v1/secrets/data/alloydb_kek)。
    2. alloydbomni.service in /etc/systemd/system/alloydbomni18.service.d/override.conf のオーバーライド ファイルを作成するには、override.conf ファイルに次のように追加します。

      [Service]
      Environment="VAULT_AUTH_TYPE"
      Environment="VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT"
      Environment="VAULT_JWT_PATH=JWT_FILE_PATH"
      Environment="VAULT_ROLE=VAULT_ROLE"
      Environment="VAULT_CERT_PATH=VAULT_CERT_PATH"
    3. 変更を適用するには、systemd デーモンを再読み込みします。

      sudo systemctl daemon-reload

    ファイルベースの KMS

    この方法はテスト目的でのみ使用してください。

    ファイルベースの鍵を使用して TDE をローカルでテストするには、まずマシンで 32 バイトの KEK を生成する必要があります。

    1. ディレクトリを作成し、鍵を生成して、適切な権限を設定します。

      KEK_DIR=KEK_DIR
      mkdir -p $KEK_DIR
      sudo chown 999:999 $KEK_DIR
      openssl rand -base64 32 | sudo tee $KEK_DIR/key
      sudo chmod 0755 $KEK_DIR/key
    2. ローカル ファイル URI を KEK URL として渡して、データベースを初期化します。

      sudo PGPASSWORD=POSTGRES_PASSWORD \
      PGDATA=DATA_DIR \
      POSTGRES_INITDB_ARGS="--tde-kek-url=file:///$KEK_DIR/key" \
      /usr/lib/postgresql/18/bin/alloydbomni18-setup initdb

      次のように置き換えます。

      • POSTGRES_PASSWORD: データベース ユーザーのパスワード。
      • DATA_DIR: AlloyDB Omni のデータボリュームとしてマウントするローカル ディレクトリ(例: /local/data)。
      • KEK_DIR: ローカル ファイルベースの KEK が保存されているディレクトリ(例: /tmp/alloydb/kms)。
  3. データベースが初期化されたら、RPM を使用して AlloyDB Omni をインストールするの手順に沿って、データベースを準備し、ホストを設定して、systemd サービスを開始します。

TDE 指標を表示する

クラスタが初期化されたら、次の手順を完了して、TDE が有効になっていることを確認し、関連する TDE 指標を表示します。

  1. psql または任意のクライアントを使用してデータベースに接続します。インスタンスへの接続方法の詳細については、 AlloyDB Omni を実行して接続するをご覧ください。
  2. 次のコマンドを実行します。

    select * FROM pgsnap.g$tde_stats;
    

    出力には、TDE が有効になっているかどうか、KEK URL、KEK バージョン、KEK 作成タイムスタンプなどの TDE 指標が表示されます。

    次の表に、各指標の意味を示します。

    名前 説明 ラベル 単位 タイプ
    alloydb_omni_database_tde_data_blocks_decrypted_count_total 復号されたデータブロックの数。 該当なし カウンタ
    alloydb_omni_database_tde_data_blocks_encrypted_count_total 暗号化されたデータブロックの数。 該当なし カウンタ
    alloydb_omni_database_tde_data_decryption_time_us_total データブロックの復号に費やされた合計時間。 該当なし マイクロ秒 カウンタ
    alloydb_omni_database_tde_data_encryption_time_us_total データブロックの暗号化に費やされた合計時間。 該当なし マイクロ秒 カウンタ
    alloydb_omni_database_tde_enabled TDE の有効ステータス。 該当なし ゲージ
    alloydb_omni_database_tde_kek_info TDE KEK 情報。
    • kek_version: 鍵のラッピングに使用される KEK
      のバージョン。
    • kek_url: KMS の KEK への完全修飾されたパス
    • kek_creation_timestamp:
      使用中の KEK バージョンの作成時間。
    ゲージ
    alloydb_omni_database_tde_temp_blocks_decrypted_count_total 復号された一時ブロックの数。 該当なし カウンタ
    alloydb_omni_database_tde_temp_blocks_encrypted_count_total 暗号化された一時ブロックの数。 該当なし カウンタ
    alloydb_omni_database_tde_temp_decryption_time_us_total 一時ブロックの復号に費やされた合計時間。 該当なし マイクロ秒 カウンタ
    alloydb_omni_database_tde_temp_encryption_time_us_total 一時ブロックの暗号化に費やされた合計時間。 該当なし マイクロ秒 カウンタ
    alloydb_omni_database_tde_wal_blocks_decrypted_count_total 復号された WAL ブロックの数。 該当なし カウンタ
    alloydb_omni_database_tde_wal_blocks_encrypted_count_total 暗号化された WAL ブロックの数。 該当なし カウンタ
    alloydb_omni_database_tde_wal_decryption_time_us_total WAL ブロックの復号に費やされた合計時間。 該当なし マイクロ秒 カウンタ
    alloydb_omni_database_tde_wal_encryption_time_us_total WAL ブロックの暗号化に費やされた合計時間。 該当なし マイクロ秒 カウンタ