En este instructivo, se muestra cómo usar la plantilla de transmisiones de flujos de cambios a Pub/Sub, incluido cómo configurar un tema y la plantilla. De manera opcional, puedes crear una función de Cloud Run en el lenguaje de programación que elijas y que se active con el flujo de eventos.
Este instructivo está dirigido a usuarios técnicos que estén familiarizados con Bigtable, la escritura de código y los servicios de transmisión de eventos.
Objetivos
En este instructivo, se muestra cómo realizar lo siguiente:
- Crea una tabla de Bigtable con un flujo de cambios habilitado.
- Crea un tema de Pub/Sub con el esquema del flujo de cambios de Bigtable.
- Implementa un flujo de cambios de Bigtable en una canalización de Pub/Sub en Dataflow con la plantilla.
- Visualiza el flujo de eventos directamente en Pub/Sub o en los registros de una función de Cloud Run.
Costos
En este documento, usarás los siguientes componentes facturables de Google Cloud:
Para generar una estimación de costos en función del uso previsto, usa la calculadora de precios.
Cuando completes las tareas que se describen en este documento, podrás borrar los recursos que creaste para evitar que se te siga facturando. Para obtener más información, consulta Realiza una limpieza.
Antes de comenzar
- Instala y actualiza la CLI de
cbt
.gcloud components update gcloud components install cbt
En la consola de Google Cloud , ve a la página Temas de Pub/Sub.
Haz clic en Crear un tema.
Configura el ID como
bigtable-change-stream-topic
.Selecciona Usar un esquema.
En el menú desplegable Selecciona un esquema de Pub/Sub, haz clic en Crear un esquema nuevo. Se abrirá una pestaña nueva en la que definirás el esquema.
- Configura el ID del esquema en
bigtable-change-stream-schema
. - Establece el tipo de esquema en Avro.
- Pega lo siguiente como la definición del esquema. Puedes encontrar más información sobre el esquema en la página de documentación de la plantilla.
{ "name" : "ChangelogEntryMessage", "type" : "record", "namespace" : "com.google.cloud.teleport.bigtable", "fields" : [ { "name" : "rowKey", "type" : "bytes"}, { "name" : "modType", "type" : { "name": "ModType", "type": "enum", "symbols": ["SET_CELL", "DELETE_FAMILY", "DELETE_CELLS", "UNKNOWN"]} }, { "name": "isGC", "type": "boolean" }, { "name": "tieBreaker", "type": "int"}, { "name": "columnFamily", "type": "string"}, { "name": "commitTimestamp", "type" : "long"}, { "name" : "sourceInstance", "type" : "string"}, { "name" : "sourceCluster", "type" : "string"}, { "name" : "sourceTable", "type" : "string"}, { "name": "column", "type" : ["null", "bytes"]}, { "name": "timestamp", "type" : ["null", "long"]}, { "name": "timestampFrom", "type" : ["null", "long"]}, { "name": "timestampTo", "type" : ["null", "long"]}, { "name" : "value", "type" : ["null", "bytes"]} ] }
- Haz clic en Crear para crear el esquema.
- Configura el ID del esquema en
Cierra la pestaña Crear esquema, actualiza la lista de esquemas y selecciona el esquema que acabas de definir.
Haz clic en Crear para crear el tema.
- En la página Detalles del tema
bigtable-change-stream-topic
, haz clic en Activar Cloud Function . - En el campo Nombre de la función, ingresa el nombre
bt-ps-tutorial-function
. - En la sección Código fuente, haz clic en el menú desplegable Entorno de ejecución y, luego, selecciona el entorno de ejecución y el lenguaje de programación que prefieras. Se genera un
hello world
que imprime el flujo de cambios a medida que llega. Consulta la documentación para obtener más información sobre cómo escribir Cloud Run Functions. - Usa los valores predeterminados en los otros campos.
- Haz clic en Implementar función.
En la consola de Google Cloud , ve a la página Instancias de Bigtable.
Haz clic en el ID de la instancia que usas para este instructivo.
Si no tienes una instancia disponible, crea una con la configuración predeterminada en una región cercana.
En el panel de navegación izquierdo, haz clic en Tablas.
Haz clic en Crea una tabla.
Asígnale el nombre
change-streams-pubsub-tutorial
a la tabla.Agrega una familia de columnas llamada
cf
.Selecciona Habilitar el flujo de cambios.
Haz clic en Crear.
- En la página Tablas de Bigtable, busca tu tabla
change-streams-pubsub-tutorial
. - En la columna Change stream, haz clic en Connect.
- En el diálogo, selecciona Pub/Sub.
- Haz clic en Crear trabajo de Dataflow.
- En la página Crear trabajo de Dataflow, configura el nombre del tema de Pub/Sub de salida como
bigtable-change-stream-topic
. - Establece el ID del perfil de aplicación de Bigtable en
default
. - Haga clic en Ejecutar trabajo.
- Espera a que el estado del trabajo sea Starting o Running antes de continuar. Tarda alrededor de 5 minutos una vez que el trabajo se pone en cola.
En Cloud Shell, escribe algunas filas en Bigtable para que el registro de cambios pueda escribir algunos datos en el flujo de Pub/Sub. Siempre y cuando escribas los datos después de que se cree el trabajo, aparecerán los cambios. No tienes que esperar a que el estado del trabajo cambie a
running
.cbt -instance=BIGTABLE_INSTANCE_ID -project=YOUR_PROJECT_ID \ set change-streams-pubsub-tutorial user123 cf:col1=abc cbt -instance=BIGTABLE_INSTANCE_ID -project=YOUR_PROJECT_ID \ set change-streams-pubsub-tutorial user546 cf:col1=def cbt -instance=BIGTABLE_INSTANCE_ID -project=YOUR_PROJECT_ID \ set change-streams-pubsub-tutorial user789 cf:col1=ghi
En la consola de Google Cloud , ve a la página Suscripciones de Pub/Sub.
Haz clic en la suscripción que se creó automáticamente para tu tema
bigtable-change-stream-topic
. Debería llamarsebigtable-change-stream-topic-sub
.Ve a la pestaña Mensajes.
Haz clic en Extraer.
Explora la lista de mensajes y visualiza los datos que escribiste.
En la Google Cloud consola, ve a Funciones de Cloud Run.
Haz clic en tu función
bt-ps-tutorial-function
.Ve a la pestaña Registros.
Asegúrate de que Severity esté configurado en, al menos, Info para que puedas ver los registros.
Explora los registros y visualiza los datos que escribiste.
En la consola de Google Cloud , ve a la página Instancias de Bigtable.
Haz clic en el ID de la instancia que usas para este instructivo.
En el panel de navegación izquierdo, haz clic en Tablas.
Busca la tabla
change-streams-pubsub-tutorial
.Haz clic en Editar.
Borra Habilitar el flujo de cambios.
Haz clic en Guardar.
Abre el menú ampliado de la tabla.
Haz clic en Borrar y, luego, ingresa el nombre de la tabla para confirmar.
En la consola de Google Cloud , ve a la página Trabajos de Dataflow.
Selecciona tu trabajo de transmisión en la lista de trabajos.
En la navegación, haz clic en Detener.
En el cuadro de diálogo Detener trabajo, cancela tu canalización y, luego, haz clic en Detener trabajo.
En la consola de Google Cloud , ve a la página Temas de Pub/Sub.
Selecciona el tema
bigtable-change-stream-topic
.Haz clic en Borrar y confirma tu decisión.
Haz clic en Suscripciones en la barra lateral.
Selecciona la suscripción a
bigtable-change-stream-topic-sub
.Haz clic en Borrar y confirma tu decisión.
En la Google Cloud consola, ve a Funciones de Cloud Run.
Selecciona la función
bt-ps-tutorial-function
.Haz clic en Borrar y confirma tu decisión.
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Verify that billing is enabled for your Google Cloud project.
Enable the Dataflow, Cloud Bigtable API, Cloud Bigtable Admin API, Pub/Sub, Cloud Run functions, and Cloud Storage APIs.
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Verify that billing is enabled for your Google Cloud project.
Enable the Dataflow, Cloud Bigtable API, Cloud Bigtable Admin API, Pub/Sub, Cloud Run functions, and Cloud Storage APIs.
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Crea un tema de Pub/Sub
Opcional: Crea una Cloud Run Function
Es posible que desees procesar el flujo de Pub/Sub con una función de Cloud Run.
Crea una tabla con una transmisión de cambios habilitada
Inicializa una canalización de datos para capturar el flujo de cambios
Escribe algunos datos en Bigtable
Cómo ver los registros de cambios en Pub/Sub
Opcional: Visualiza los cambios en los registros de Cloud Run Functions
Si creaste una función de Cloud Run Functions, puedes ver los cambios en los registros.
El resultado es similar al siguiente:
Pub/Sub message: {"rowKey":"user789","modType":"SET_CELL","isGC":false,"tieBreaker":0,"columnFamily":"cf","commitTimestamp":1695653833064548,"sourceInstance":"YOUR-INSTANCE","sourceCluster":"YOUR-INSTANCE-c1","sourceTable":"change-streams-pubsub-tutorial","column":{"bytes":"col1"},"timestamp":{"long":1695653832278000},"timestampFrom":null,"timestampTo":null,"value":{"bytes":"ghi"}}
Limpia
Para evitar que se apliquen cargos a tu cuenta de Google Cloud por los recursos usados en este instructivo, borra el proyecto que contiene los recursos o conserva el proyecto y borra los recursos individuales.