O modelo Apache Kafka para Cloud Storage é um pipeline de streaming que ingere dados de texto do Google Cloud Managed Service para Apache Kafka e envia os registros para o Cloud Storage.
Também é possível usar o modelo Apache Kafka para BigQuery com o Kafka autogerenciado ou externo.
Requisitos de pipeline
- O bucket de saída do Cloud Storage precisa existir.
- O servidor do agente do Apache Kafka precisa estar em execução e acessível em máquinas de trabalho do Dataflow.
- Os tópicos do Apache Kafka precisam existir.
Formato de mensagem do Kafka
Esse modelo oferece suporte à leitura de mensagens do Kafka nos seguintes formatos:
Formato JSON
Para ler mensagens JSON, defina o parâmetro de modelo messageFormat
como
"JSON"
.
Codificação binária Avro
Para ler mensagens Avro binárias, defina os seguintes parâmetros de modelo:
messageFormat
:"AVRO_BINARY_ENCODING"
.binaryAvroSchemaPath
: o local de um arquivo de esquema Avro no Cloud Storage. Exemplo:gs://BUCKET_NAME/message-schema.avsc
.
Para mais informações sobre o formato binário Avro, consulte Codificação binária na documentação do Apache Avro.
Avro codificado pelo Confluent Schema Registry
Para ler mensagens em Avro codificado pelo Confluent Schema Registry, defina os seguintes parâmetros de modelo:
messageFormat
:"AVRO_CONFLUENT_WIRE_FORMAT"
.schemaFormat
: um dos seguintes valores:"SINGLE_SCHEMA_FILE"
: o esquema da mensagem é definido em um arquivo de esquema Avro. Especifique o local do Cloud Storage do arquivo de esquema no parâmetroconfluentAvroSchemaPath
.-
"SCHEMA_REGISTRY"
: as mensagens são codificadas usando o Confluent Schema Registry. Especifique o URL da instância do Confluent Schema Registry no parâmetroschemaRegistryConnectionUrl
e o modo de autenticação no parâmetroschemaRegistryAuthenticationMode
.
Para mais informações sobre esse formato, consulte Formato de transmissão na documentação da Confluent.
Formato de arquivo de saída
O formato do arquivo de saída é igual à mensagem de entrada do Kafka. Por exemplo, se você selecionar JSON para o formato de mensagem do Kafka, os arquivos JSON serão gravados no bucket de saída do Cloud Storage.
Autenticação
O modelo Apache Kafka para Cloud Storage oferece suporte à autenticação SASL/PLAIN para agentes Kafka.
Parâmetros do modelo
Parâmetros obrigatórios
- readBootstrapServerAndTopic: o tópico do Kafka a ser usado para ler a entrada.
- outputDirectory: o caminho e o prefixo do nome do arquivo para gravar arquivos de saída. Precisa terminar com uma barra. Por exemplo,
gs://your-bucket/your-path/
. - kafkaReadAuthenticationMode: o modo de autenticação a ser usado com o cluster do Kafka. Use
KafkaAuthenticationMethod.NONE
para nenhuma autenticação,KafkaAuthenticationMethod.SASL_PLAIN
para nome de usuário e senha SASL/PLAIN,KafkaAuthenticationMethod.SASL_SCRAM_512
para autenticação SASL_SCRAM_512 eKafkaAuthenticationMethod.TLS
para autenticação com base em certificado.KafkaAuthenticationMethod.APPLICATION_DEFAULT_CREDENTIALS
só deve ser usado para o cluster do Google Cloud Apache Kafka para BigQuery. Ele permite a autenticação usando credenciais padrão do aplicativo. - messageFormat: o formato das mensagens do Kafka a serem lidas. Os valores aceitos são
AVRO_CONFLUENT_WIRE_FORMAT
(Avro codificado do Confluent Schema Registry),AVRO_BINARY_ENCODING
(Avro binário simples) eJSON
. O padrão é: AVRO_CONFLUENT_WIRE_FORMAT. - useBigQueryDLQ: se verdadeiro, as mensagens com falha serão gravadas no BigQuery com informações extras sobre o erro. O padrão é: falso.
Parâmetros opcionais
- windowDuration: a duração/tamanho da janela em que os dados serão gravados no Cloud Storage. Os formatos permitidos são: Ns (para segundos, exemplo: "5s"), Nm (para minutos, exemplo: "12m") e Nh (para horas, exemplo: "2h"). Por exemplo,
5m
. O padrão é de 5 minutos. - outputFilenamePrefix: o prefixo a ser colocado em cada arquivo em janela. Por exemplo,
output-
. O padrão é: saída. - numShards: o número máximo de fragmentos de saída produzidos durante a gravação. Um número maior de fragmentos significa maior capacidade de gravação no Cloud Storage, mas um custo de agregação de dados potencialmente maior entre os fragmentos ao processar os arquivos de saída do Cloud Storage. O valor padrão é decidido pelo Dataflow.
- enableCommitOffsets: deslocamentos de confirmação de mensagens processadas para o Kafka. Se ativado, isso minimizará as lacunas ou o processamento duplicado de mensagens ao reiniciar o pipeline. Exige especificar o ID do grupo de consumidores. O padrão é: falso.
- consumerGroupId: o identificador exclusivo do grupo de consumidores ao qual esse pipeline pertence. Obrigatório se os deslocamentos de confirmação para Kafka estiverem ativados. O padrão é vazio.
- kafkaReadOffset: o ponto de partida para ler mensagens quando não há deslocamentos confirmados. O mais antigo começa no início, o mais recente a partir da mensagem mais recente. O padrão é: mais recente.
- kafkaReadUsernameSecretId: o ID do secret do Google Cloud Secret Manager que contém o nome de usuário do Kafka a ser usado com a autenticação
SASL_PLAIN
. Por exemplo,projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. O padrão é vazio. - kafkaReadPasswordSecretId: o ID do secret do Google Cloud Secret Manager que contém a senha do Kafka a ser usada com a autenticação
SASL_PLAIN
. Por exemplo,projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. O padrão é vazio. - kafkaReadKeystoreLocation: o caminho do Google Cloud Storage para o arquivo Java KeyStore (JKS) que contém o certificado TLS e a chave privada a serem usados na autenticação com o cluster do Kafka. Por exemplo,
gs://your-bucket/keystore.jks
. - kafkaReadTruststoreLocation: o caminho do Google Cloud Storage para o arquivo Java TrustStore (JKS) que contém os certificados confiáveis a serem usados para verificar a identidade do agente Kafka.
- kafkaReadTruststorePasswordSecretId: o ID do secret do Google Cloud Secret Manager que contém a senha usada para acessar o arquivo Java TrustStore (JKS) para autenticação TLS do Kafka. Por exemplo,
projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. - kafkaReadKeystorePasswordSecretId: o ID do secret do Google Cloud Secret Manager que contém a senha usada para acessar o arquivo Java KeyStore (JKS) para a autenticação TLS do Kafka. Por exemplo,
projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. - kafkaReadKeyPasswordSecretId: o ID do secret do Secret Manager do Google Cloud que contém a senha usada para acessar a chave privada no arquivo Java KeyStore (JKS) para a autenticação TLS do Kafka. Por exemplo,
projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. - kafkaReadSaslScramUsernameSecretId: o ID do secret do Google Cloud Secret Manager que contém o nome de usuário do Kafka a ser usado com a autenticação
SASL_SCRAM
. Por exemplo,projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. - kafkaReadSaslScramPasswordSecretId: o ID do secret do Google Cloud Secret Manager que contém a senha do Kafka a ser usada com a autenticação
SASL_SCRAM
. Por exemplo,projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. - kafkaReadSaslScramTruststoreLocation: o caminho do Google Cloud Storage para o arquivo Java TrustStore (JKS) que contém os certificados confiáveis a serem usados para verificar a identidade do agente Kafka.
- kafkaReadSaslScramTruststorePasswordSecretId: o ID do secret do Google Cloud Secret Manager que contém a senha usada para acessar o arquivo Java TrustStore (JKS) para autenticação SASL_SCRAM do Kafka. Por exemplo,
projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. - schemaFormat: o formato de esquema do Kafka. Pode ser fornecido como
SINGLE_SCHEMA_FILE
ouSCHEMA_REGISTRY
. SeSINGLE_SCHEMA_FILE
for especificado, use o esquema mencionado no arquivo de esquema Avro para todas as mensagens. SeSCHEMA_REGISTRY
for especificado, as mensagens poderão ter um único esquema ou vários esquemas. O padrão é SINGLE_SCHEMA_FILE. - confluentAvroSchemaPath: o caminho do Google Cloud Storage para o único arquivo de esquema Avro usado para decodificar todas as mensagens em um tópico. O padrão é vazio.
- schemaRegistryConnectionUrl: o URL da instância do Confluent Schema Registry usada para gerenciar esquemas Avro para decodificação de mensagens. O padrão é vazio.
- binaryAvroSchemaPath: o caminho do Google Cloud Storage para o arquivo de esquema do Avro usado para decodificar mensagens Avro codificadas em binário. O padrão é vazio.
- schemaRegistryAuthenticationMode: modo de autenticação do registro de esquema. Pode ser NONE, TLS ou OAUTH. O padrão é: NENHUM.
- schemaRegistryTruststoreLocation: local do certificado SSL em que o Truststore para autenticação no Schema Registry está armazenado. Por exemplo,
/your-bucket/truststore.jks
. - schemaRegistryTruststorePasswordSecretId: SecretId no Secret Manager em que a senha para acessar o secret no truststore é armazenada. Por exemplo,
projects/your-project-number/secrets/your-secret-name/versions/your-secret-version
. - schemaRegistryKeystoreLocation: local do keystore que contém o certificado SSL e a chave privada. Por exemplo,
/your-bucket/keystore.jks
. - schemaRegistryKeystorePasswordSecretId: SecretId no Secret Manager em que a senha para acessar o arquivo do keystore. Por exemplo,
projects/your-project-number/secrets/your-secret-name/versions/your-secret-version
. - schemaRegistryKeyPasswordSecretId: SecretId da senha necessária para acessar a chave privada do cliente armazenada no keystore. Por exemplo,
projects/your-project-number/secrets/your-secret-name/versions/your-secret-version
. - schemaRegistryOauthClientId: ID do cliente usado para autenticar o cliente do registro de esquema no modo OAUTH. Obrigatório para o formato de mensagem AVRO_CONFLUENT_WIRE_FORMAT.
- schemaRegistryOauthClientSecretId: o ID do secret do Secret Manager do Google Cloud que contém a chave secreta do cliente a ser usada para autenticar o cliente do Schema Registry no modo OAUTH. Obrigatório para o formato de mensagem AVRO_CONFLUENT_WIRE_FORMAT. Por exemplo,
projects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>
. - schemaRegistryOauthScope: o escopo do token de acesso usado para autenticar o cliente do Schema Registry no modo OAUTH. Esse campo é opcional, já que a solicitação pode ser feita sem um parâmetro de escopo transmitido. Por exemplo,
openid
. - schemaRegistryOauthTokenEndpointUrl: o URL baseado em HTTP(S) do provedor de identidade OAuth/OIDC usado para autenticar o cliente do Schema Registry no modo OAUTH. Obrigatório para o formato de mensagem AVRO_CONFLUENT_WIRE_FORMAT.
- outputDeadletterTable: nome totalmente qualificado da tabela do BigQuery para mensagens com falha. As mensagens não chegam à tabela de saída por diferentes motivos (por exemplo, esquema incompatível, json incorreto) são gravadas nesta tabela, que é criada pelo modelo. Por exemplo,
your-project-id:your-dataset.your-table-name
.
Executar o modelo
Console
- Acesse a página Criar job usando um modelo do Dataflow. Acesse Criar job usando um modelo
- No campo Nome do job, insira um nome exclusivo.
- Opcional: em Endpoint regional, selecione um valor no menu suspenso. A região padrão é
us-central1
.Para ver uma lista de regiões em que é possível executar um job do Dataflow, consulte Locais do Dataflow.
- No menu suspenso Modelo do Dataflow, selecione the Kafka to Cloud Storage template.
- Nos campos de parâmetro fornecidos, insira os valores de parâmetro.
- Opcional: para alternar do processamento "Exatamente uma vez" para o modo de streaming "Pelo menos uma vez", selecione Pelo menos uma vez.
- Cliquem em Executar job.
gcloud
No shell ou no terminal, execute o modelo:
gcloud dataflow flex-template run JOB_NAME \ --project=PROJECT_ID \ --region=REGION_NAME \ --template-file-gcs-location=gs://dataflow-templates-REGION_NAME/VERSION/flex/Kafka_to_Gcs_Flex \ --parameters \ readBootstrapServerAndTopic=BOOTSTRAP_SERVER_AND_TOPIC,\ kafkaReadAuthenticationMode=APPLICATION_DEFAULT_CREDENTIALS,\ messageFormat=JSON,\ outputDirectory=gs://STORAGE_BUCKET_NAME,\ useBigQueryDLQ=false
Substitua:
PROJECT_ID
: o ID do projeto Google Cloud em que você quer executar o job do DataflowJOB_NAME
: um nome de job de sua escolhaREGION_NAME
: a região onde você quer implantar o job do Dataflow, por exemplo,us-central1
VERSION
: a versão do modelo que você quer usarUse estes valores:
latest
para usar a versão mais recente do modelo, disponível na pasta mãe não datada no bucket: gs://dataflow-templates-REGION_NAME/latest/- o nome da versão, como
2023-09-12-00_RC00
, para usar uma versão específica do modelo, que pode ser encontrada aninhada na respectiva pasta mãe datada no bucket: gs://dataflow-templates-REGION_NAME/
BOOTSTRAP_SERVER_AND_TOPIC
: o endereço do servidor de inicialização e o tópico do Apache Kafka.O formato do endereço do servidor de inicialização e do tópico depende do tipo de cluster:
- Cluster do Serviço gerenciado para Apache Kafka:
projects/PROJECT_ID/locations/REGION_NAME/clusters/CLUSTER_NAME/topics/TOPIC_NAME
- Cluster externo do Kafka:
BOOTSTRAP_SERVER_ADDRESS;TOPIC_NAME
- Cluster do Serviço gerenciado para Apache Kafka:
STORAGE_BUCKET_NAME
: o bucket do Cloud Storage em que a saída é gravada
API
Para executar o modelo usando a API REST, envie uma solicitação HTTP POST. Para mais informações sobre a
API e os respectivos escopos de autorização, consulte
projects.templates.launch
.
POST https://dataflow.googleapis.com/v1b3/projects/PROJECT_ID/locations/LOCATION/flexTemplates:launch { "launch_parameter": { "jobName": "JOB_NAME", "parameters": { "readBootstrapServerAndTopic": "BOOTSTRAP_SERVER_AND_TOPIC", "kafkaReadAuthenticationMode": "APPLICATION_DEFAULT_CREDENTIALS", "messageFormat": "JSON", "outputDirectory": "gs://STORAGE_BUCKET_NAME", "useBigQueryDLQ": "false" }, "containerSpecGcsPath": "gs://dataflow-templates-LOCATION/VERSION/flex/Kafka_to_Gcs_Flex", } }
Substitua:
PROJECT_ID
: o ID do projeto Google Cloud em que você quer executar o job do DataflowJOB_NAME
: um nome de job de sua escolhaLOCATION
: a região onde você quer implantar o job do Dataflow, por exemplo,us-central1
VERSION
: a versão do modelo que você quer usarUse estes valores:
latest
para usar a versão mais recente do modelo, disponível na pasta mãe não datada no bucket: gs://dataflow-templates-REGION_NAME/latest/- o nome da versão, como
2023-09-12-00_RC00
, para usar uma versão específica do modelo, que pode ser encontrada aninhada na respectiva pasta mãe datada no bucket: gs://dataflow-templates-REGION_NAME/
BOOTSTRAP_SERVER_AND_TOPIC
: o endereço do servidor de inicialização e o tópico do Apache Kafka.O formato do endereço do servidor de inicialização e do tópico depende do tipo de cluster:
- Cluster do Serviço gerenciado para Apache Kafka:
projects/PROJECT_ID/locations/LOCATION/clusters/CLUSTER_NAME/topics/TOPIC_NAME
- Cluster externo do Kafka:
BOOTSTRAP_SERVER_ADDRESS;TOPIC_NAME
- Cluster do Serviço gerenciado para Apache Kafka:
STORAGE_BUCKET_NAME
: o bucket do Cloud Storage em que a saída é gravada
A seguir
- Saiba mais sobre os modelos do Dataflow.
- Confira a lista de modelos fornecidos pelo Google.