Criar um cluster com TDE ativada

Selecione uma versão da documentação:

Para ativar a criptografia de dados transparente (TDE), forneça as variáveis de ambiente necessárias do cofre e inclua a flag --tde-kek-url no POSTGRES_INITDB_ARGS.

Antes de começar

Crie o cluster

Para criar um cluster com TDE, transmita a configuração e as credenciais de autenticação necessárias do Key Management Service (KMS) durante a inicialização do banco de dados. O único tipo de autenticação compatível é jwt.

Selecione a guia do ambiente de execução do contêiner.

Docker

docker run -d --name CONTAINER_NAME \
--network host \
-v DATA_DIR:/var/lib/postgresql/data \
-v VAULT_CERT_PATH_ON_DISK:VAULT_CERT_PATH \
-e VAULT_AUTH_TYPE=jwt \
-e VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \
-e VAULT_JWT_PATH=JWT_FILE_PATH \
-e VAULT_ROLE=VAULT_ROLE \
-e VAULT_CERT_PATH=VAULT_CERT_PATH \
-e POSTGRES_INITDB_ARGS=" \
--tde-kek-url=KEK_URL" \
google/alloydbomni:IMAGE_TAG

Docker

docker run -d --name CONTAINER_NAME \
--network host \
-v DATA_DIR:/var/lib/postgresql/data \
-v VAULT_CERT_PATH_ON_DISK:VAULT_CERT_PATH \
-e VAULT_AUTH_TYPE=jwt \
-e VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \
-e VAULT_JWT_PATH=JWT_FILE_PATH \
-e VAULT_ROLE=VAULT_ROLE \
-e VAULT_CERT_PATH=VAULT_CERT_PATH \
-e POSTGRES_INITDB_ARGS=" \
--tde-kek-url=KEK_URL" \
google/alloydbomni:IMAGE_TAG

Podman

podman run -d --name CONTAINER_NAME \
--network host \
-v DATA_DIR:/var/lib/postgresql/data \
-v VAULT_CERT_PATH_ON_DISK:VAULT_CERT_PATH \
-e VAULT_AUTH_TYPE=jwt \
-e VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \
-e VAULT_JWT_PATH=JWT_FILE_PATH \
-e VAULT_ROLE=VAULT_ROLE \
-e VAULT_CERT_PATH=VAULT_CERT_PATH \
-e POSTGRES_INITDB_ARGS=" \
--tde-kek-url=KEK_URL" \
google/alloydbomni:IMAGE_TAG

Podman

podman run -d --name CONTAINER_NAME \
--network host \
-v DATA_DIR:/var/lib/postgresql/data \
-v VAULT_CERT_PATH_ON_DISK:VAULT_CERT_PATH \
-e VAULT_AUTH_TYPE=jwt \
-e VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \
-e VAULT_JWT_PATH=JWT_FILE_PATH \
-e VAULT_ROLE=VAULT_ROLE \
-e VAULT_CERT_PATH=VAULT_CERT_PATH \
-e POSTGRES_INITDB_ARGS=" \
--tde-kek-url=KEK_URL" \
google/alloydbomni:IMAGE_TAG

Substitua:

  • CONTAINER_NAME: o nome do contêiner a ser criado. Por exemplo, alloydb-tde.
  • DATA_DIR: o diretório local a ser montado como o volume de dados do AlloyDB Omni. Por exemplo, /local/data.
  • VAULT_AUTH_TYPE: o tipo de autenticação a ser usado para a conexão do cofre. Somente jwt é aceito.
  • JWT_AUTH_ENGINE_MOUNT: caminho em que o mecanismo de autenticação do HashiCorp Vault está montado. Por exemplo, /auth/jwt.
  • JWT_FILE_PATH: caminho onde o JWT do Vault é armazenado nos seus nós. Por exemplo, tde-tls/jwt-token.
  • (Opcional) VAULT_ROLE: a função do cliente definida na configuração do Vault que permite ao HashiCorp Vault verificar a autenticidade do token JWT.
  • VAULT_CERT_PATH_ON_DISK: caminho para os certificados do Vault na máquina host. Por exemplo, /local/vault/config.
  • VAULT_CERT_PATH: caminho em que os certificados para a conexão do cofre estão localizados no contêiner. Por exemplo, /tde-tls. Se não for definido, os certificados no armazenamento de confiança padrão serão usados.
  • KEK_URL: o URL totalmente qualificado para a KEK no HashiCorp Vault. Use vault como o protocolo para especificar o HashiCorp Vault como o provedor de KMS. Por exemplo, vault://127.0.0.1:8200/v1/secrets/data/alloydb_kek.
  • IMAGE_TAG: use 18.1.0 para a imagem mais recente do Debian ou 18.1.0-ubi para a imagem mais recente do UBI.

Conferir métricas de TDE

Depois que o cluster for inicializado, conclua as etapas a seguir para verificar se o TDE está ativado e conferir as métricas relacionadas.

  1. Conecte-se ao banco de dados usando psql ou seu cliente preferido. Para instruções detalhadas sobre como se conectar às instâncias, consulte Executar e se conectar ao AlloyDB Omni.
  2. Execute este comando:

    select * FROM pgsnap.g$tde_stats;
    

    A saída mostra métricas de TDE, como se o TDE está ativado, o URL da KEK, a versão da KEK e o carimbo de data/hora de criação da KEK.

    A tabela a seguir explica o significado de cada métrica.

    Nome Descrição Rótulo Unidade Tipo
    alloydb_omni_database_tde_data_blocks_decrypted_count_total Número de blocos de dados descriptografados. Não relevante Contador
    alloydb_omni_database_tde_data_blocks_encrypted_count_total Número de blocos de dados criptografados. Não relevante Contador
    alloydb_omni_database_tde_data_decryption_time_us_total Tempo total gasto na descriptografia do bloco de dados. Não relevante microssegundos Contador
    alloydb_omni_database_tde_data_encryption_time_us_total Tempo total gasto na criptografia de blocos de dados. Não relevante microssegundos Contador
    alloydb_omni_database_tde_enabled Status de ativação do TDE. Não relevante medidor
    alloydb_omni_database_tde_kek_info Informações da KEK da TDE.
    • kek_version: versão da KEK
      em uso para encapsulamento de chaves.
    • kek_url: caminho totalmente qualificado
      para KEK no KMS
    • kek_creation_timestamp:
      horário de criação da versão da KEK em uso.
    medidor
    alloydb_omni_database_tde_temp_blocks_decrypted_count_total Número de blocos temporários descriptografados. Não relevante Contador
    alloydb_omni_database_tde_temp_blocks_encrypted_count_total Número de blocos temporários criptografados. Não relevante Contador
    alloydb_omni_database_tde_temp_decryption_time_us_total Tempo total gasto na descriptografia de bloqueio temporário. Não relevante microssegundos Contador
    alloydb_omni_database_tde_temp_encryption_time_us_total Tempo total gasto na criptografia de bloqueio temporário. Não relevante microssegundos Contador
    alloydb_omni_database_tde_wal_blocks_decrypted_count_total Número de blocos de WAL descriptografados. Não relevante Contador
    alloydb_omni_database_tde_wal_blocks_encrypted_count_total Número de blocos WAL criptografados. Não relevante Contador
    alloydb_omni_database_tde_wal_decryption_time_us_total Tempo total gasto na descriptografia do bloco WAL. Não relevante microssegundos Contador
    alloydb_omni_database_tde_wal_encryption_time_us_total Tempo total gasto na criptografia de blocos WAL. Não relevante microssegundos Contador