En Pub/Sub, un tema es un recurso con nombre que representa un feed de mensajes. Debes crear un tema para poder publicarlo o suscribirte que se les asigna. Pub/Sub admite dos tipos de temas: un tema estándar y un tema de importación.
En este documento, se describe cómo crear un tema estándar de Pub/Sub. Si quieres obtener más información sobre un tema de importación y cómo crear uno, consulta Cómo crear un tema de importación.
Para crear un tema, puedes usar la consola de Google Cloud, Google Cloud CLI, la biblioteca cliente o la API de Pub/Sub.
Antes de comenzar
Obtén más información sobre el servicio de Pub/Sub y su terminología.
Obtén más información sobre el proceso de publicación.
Roles y permisos obligatorios para administrar temas
Para obtener los permisos que necesitas para crear y administrar temas,
pídele a tu administrador que te otorgue el rol de IAM de editor de Pub/Sub(roles/pubsub.editor
)
en tu tema o proyecto.
Si quieres obtener más información para otorgar roles, consulta Administra el acceso a proyectos, carpetas y organizaciones.
Este rol predefinido contiene los permisos necesarios para crear y administrar temas. Para ver los permisos exactos que son necesarios, expande la sección Permisos requeridos:
Permisos necesarios
Se requieren los siguientes permisos para crear y administrar temas:
-
Crea un tema:
pubsub.topics.create
-
Borrar un tema:
pubsub.topics.delete
-
Desconecta una suscripción de un tema:
pubsub.topics.detachSubscription
-
Obtén un tema:
pubsub.topics.get
-
Obtén una lista de un tema:
pubsub.topics.list
-
Publicar en un tema:
pubsub.topics.publish
-
Actualiza un tema:
pubsub.topics.update
-
Obtén la política de IAM para un tema:
pubsub.topics.getIamPolicy
-
Configura la política de IAM para un tema:
pubsub.topics.setIamPolicy
También puedes obtener estos permisos con roles personalizados o con otros roles predefinidos.
Puedes configurar el control de acceso a nivel de proyecto y a nivel individual a nivel de los recursos. Puedes crear una suscripción en un proyecto adjuntarlo a un tema ubicado en un proyecto diferente. Asegúrate de tener los permisos necesarios para cada proyecto.
Propiedades de un tema
Cuando creas o actualizas un tema, debes especificar sus propiedades.
-
Agrega una suscripción predeterminada. Agrega una suscripción predeterminada al tema de Pub/Sub. Puedes crear otra suscripción para el tema después de crearlo. La suscripción predeterminada tiene la siguientes propiedades:
- ID de suscripción de
-sub
- Tipo de entrega de extracción
- Período de retención de mensajes de siete días
- Vencimiento después de 31 días de inactividad
- El plazo límite de confirmación de recepción es de 10 segundos
- Política de reintento inmediato
- ID de suscripción de
- Esquema. Un esquema es un formato que debe seguir el campo de datos del mensaje. Un esquema es un contrato entre el publicador y el suscriptor que Pub/Sub aplica. Los esquemas de temas ayudan a estandarizar tipos de mensajes y permisos para permitirles que los usen diferentes equipos de tu organización. Pub/Sub crea un autoridad para los tipos de mensajes y permisos. Para crear un tema con , consulta Descripción general del esquema.
-
Habilita la transferencia. Habilitar esta propiedad te permite transferir datos de transmisión de fuentes externas a un tema para que puedan aprovechar las funciones de Google Cloud. Para crear un tema de importación Para la transferencia, consulta Crea un tema de importación.
-
Duración de la retención de mensajes. Especifica la duración El tema de Pub/Sub conserva los mensajes después de la publicación. Después del cuando finalice la retención de mensajes, es posible que Pub/Sub descarte el mensaje independientemente de su estado de confirmación. Tarifas de almacenamiento de mensajes se cobran por almacenar todos los mensajes publicados en el tema.
- Configuración predeterminada = No habilitada
- Valor mínimo = 10 minutos
- Valor máximo = 31 días
- Usa una clave de encriptación administrada por el cliente (CMEK). Especifica si el tema está encriptado con una CMEK. Pub/Sub encripta los mensajes con claves de Google y claves administradas por Google de forma predeterminada. Si especificas esta opción, Pub/Sub usa el patrón de encriptación de sobre con CMEK. En este enfoque, Cloud KMS no encripta los mensajes. En cambio, Cloud KMS Encripta las claves de encriptación de datos (DEK) que crea Pub/Sub. para cada tema. Pub/Sub encripta los mensajes con el método DEK que se generó para el tema. Pub/Sub desencripta los mensajes de error poco antes de entregarlos a los suscriptores. Para ver más información sobre cómo crear una clave, consulta Configura la encriptación de mensajes.
Crea un tema
Crea un tema antes de publicarlo o suscribirte a él.
Console
Para crear un tema, sigue estos pasos:
En la consola de Google Cloud, ve a la página Temas de Pub/Sub.
Haga clic en Crear tema.
En el campo ID de tema, ingresa un ID para tu tema. Para obtener más información sobre la asignación de nombres de temas, consulta los lineamientos para asignar nombres.
Mantén la opción Agregar una suscripción predeterminada.
No selecciones las otras opciones.
Haz clic en Crear tema.
gcloud
-
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.
-
Para crear un tema, ejecuta Comando
gcloud pubsub topics create
:gcloud pubsub topics create TOPIC_ID
REST
Para crear un tema, usa el método projects.topics.create
:
La solicitud debe autenticarse con un token de acceso en el encabezado Authorization
. A fin de obtener un token de acceso para las credenciales predeterminadas actuales de la aplicación, usa el siguiente comando: gcloud auth application-default print-access-token
.
PUT https://pubsub.googleapis.com/v1/projects/PROJECT_ID/topics/TOPIC_ID Authorization: Bearer ACCESS_TOKEN
Aquí:
Respuesta:
{ "name": "projects/PROJECT_ID/topics/TOPIC_ID" }
C++
Antes de probar esta muestra, sigue las instrucciones de configuración de C++ que se encuentran en el Guía de inicio rápido de Pub/Sub con bibliotecas cliente. Para obtener más información, consulta la API de C++ de Pub/Sub documentación de referencia.
Para autenticarte en Pub/Sub, configura las credenciales predeterminadas de la aplicación. Si deseas obtener más información, consulta Configura la autenticación para un entorno de desarrollo local.
C#
Antes de probar esta muestra, sigue las instrucciones de configuración de C# que encontrarás en la guía de inicio rápido de Pub/Sub con bibliotecas cliente. Si quieres obtener más información, consulta la documentación de referencia de la API de C# de Pub/Sub.
Para autenticarte en Pub/Sub, configura las credenciales predeterminadas de la aplicación. Si deseas obtener más información, consulta Configura la autenticación para un entorno de desarrollo local.
Go
Antes de probar esta muestra, sigue las instrucciones de configuración de Go que se encuentran en el Guía de inicio rápido de Pub/Sub con bibliotecas cliente. Para obtener más información, consulta la API de Go de Pub/Sub documentación de referencia.
Para autenticarte en Pub/Sub, configura las credenciales predeterminadas de la aplicación. Si deseas obtener más información, consulta Configura la autenticación para un entorno de desarrollo local.
Java
Antes de probar esta muestra, sigue las instrucciones de configuración de Java que se encuentran en el Guía de inicio rápido de Pub/Sub con bibliotecas cliente. Si quieres obtener más información, consulta la documentación de referencia de la API de Java de Pub/Sub.
Para autenticarte en Pub/Sub, configura las credenciales predeterminadas de la aplicación. Si deseas obtener más información, consulta Configura la autenticación para un entorno de desarrollo local.
Node.js
Node.js
PHP
Antes de probar esta muestra, sigue las instrucciones de configuración de PHP que se encuentran en el Guía de inicio rápido de Pub/Sub con bibliotecas cliente. Para obtener más información, consulta la API de PHP de Pub/Sub documentación de referencia.
Para autenticarte en Pub/Sub, configura las credenciales predeterminadas de la aplicación. Si deseas obtener más información, consulta Configura la autenticación para un entorno de desarrollo local.
Python
Antes de probar esta muestra, sigue las instrucciones de configuración de Python que encontrarás en la guía de inicio rápido de Pub/Sub con bibliotecas cliente. Para obtener más información, consulta la API de Python de Pub/Sub documentación de referencia.
Para autenticarte en Pub/Sub, configura las credenciales predeterminadas de la aplicación. Si deseas obtener más información, consulta Configura la autenticación para un entorno de desarrollo local.
Ruby
Antes de probar esta muestra, sigue las instrucciones de configuración de Ruby que se encuentran en el Guía de inicio rápido de Pub/Sub con bibliotecas cliente. Para obtener más información, consulta la API de Ruby de Pub/Sub documentación de referencia.
Para autenticarte en Pub/Sub, configura las credenciales predeterminadas de la aplicación. Si deseas obtener más información, consulta Configura la autenticación para un entorno de desarrollo local.
Restricciones de las políticas de la organización
Las políticas de la organización pueden restringir la creación de temas, por ejemplo, una política puede restringir el almacenamiento de mensajes en una Compute Engine región. Para evitar errores de creación de temas, examina y actualiza las políticas de la organización según sea necesario antes de crear un tema.
Si tu proyecto se creó hace poco, espera unos minutos la política de la organización para inicializar antes de crear un tema.
Ir a Políticas de la organización
Para obtener más información, consulta Configura políticas de almacenamiento de mensajes.
¿Qué sigue?
Elige el tipo de suscripción de tu tema.
Obtén más información para publicar un mensaje en un tema.
Crea o modifica un tema con gcloud CLI, APIs de REST o bibliotecas cliente.