Cuando creas una suscripción, la vinculas a un tema y los suscriptores pueden recibir mensajes de la suscripción. Para evitar que los suscriptores reciban mensajes, puedes desvincular las suscripciones del tema.
Antes de separar una suscripción, necesitas el permiso pubsub.topics.detachSubscription
en el tema. Puedes separar una suscripción sin tener permisos en ella, lo que resulta útil para gestionar un tema que se encuentre en un proyecto distinto al de la suscripción. Para obtener más información, consulta la página sobre el control de acceso de Pub/Sub.
Antes de empezar
- Consulta información sobre las suscripciones.
- Crea una de las siguientes suscripciones: pull, push o BigQuery.
Roles y permisos necesarios
Para obtener los permisos que necesitas para separar suscripciones y gestionarlas, pide a tu administrador que te conceda el rol de gestión de identidades y accesos Editor de Pub/Sub (roles/pubsub.editor
) en tu tema o proyecto.
Para obtener más información sobre cómo conceder roles, consulta el artículo Gestionar el acceso a proyectos, carpetas y organizaciones.
Este rol predefinido contiene los permisos necesarios para separar suscripciones y gestionarlas. Para ver los permisos exactos que se necesitan, despliega la sección Permisos necesarios:
Permisos obligatorios
Para separar suscripciones y gestionarlas, se necesitan los siguientes permisos:
-
Extraer de una suscripción:
pubsub.subscriptions.consume
-
Crear una suscripción:
pubsub.subscriptions.create
-
Eliminar una suscripción:
pubsub.subscriptions.delete
-
Obtener una suscripción:
pubsub.subscriptions.get
-
Mostrar una suscripción:
pubsub.subscriptions.list
-
Actualizar una suscripción:
pubsub.subscriptions.update
-
Adjuntar una suscripción a un tema:
pubsub.topics.attachSubscription
-
Obtener la política de gestión de identidades y accesos de una suscripción:
pubsub.subscriptions.getIamPolicy
-
Configura la política de gestión de identidades y accesos de una suscripción:
pubsub.subscriptions.setIamPolicy
También puedes obtener estos permisos con roles personalizados u otros roles predefinidos.
Puede configurar el control de acceso a nivel de proyecto y de recurso individual. Puedes crear una suscripción en un proyecto y adjuntarla a un tema ubicado en otro proyecto. Asegúrate de que tienes los permisos necesarios para cada proyecto.
Desvincular una suscripción de un tema
Puedes desvincular una suscripción de un tema mediante la Google Cloud consola, la CLI de Google Cloud, la biblioteca de cliente o la API Pub/Sub.
Consola
Para desvincular una suscripción, sigue estos pasos:
En la Google Cloud consola, ve a la página Temas.
Selecciona el tema del que quieras separar una suscripción.
En la pestaña Suscripciones, selecciona la suscripción que quieras desvincular.
En la página Detalles de la suscripción, haz clic en Desvincular.
En el cuadro de diálogo que aparece, vuelve a hacer clic en Desvincular.
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 desvincular una suscripción, usa el comando
gcloud pubsub topics detach-subscription
:gcloud pubsub topics detach-subscription SUBSCRIPTION_ID
Si la solicitud se realiza correctamente, la línea de comandos muestra una confirmación:
Detached subscription [SUBSCRIPTION_ID].
- PROJECT_ID es el ID del proyecto.
- SUBSCRIPTION_ID es el ID de tu suscripción.
REST
Para separar una suscripción, usa el método projects.subscriptions.detach
.
Solicitud:
La solicitud debe autenticarse con un token de acceso en el encabezado Authorization
. Para obtener un token de acceso para las credenciales predeterminadas de la aplicación actual, usa el comando
gcloud auth application-default print-access-token
.
POST https://pubsub.googleapis.com/v1/projects/PROJECT_ID/subscriptions/SUBSCRIPTION_ID:detach Authorization: Bearer ACCESS_TOKEN
Donde:
Respuesta:
Si la solicitud se realiza correctamente, la respuesta es un objeto JSON vacío.
C++
Antes de probar este ejemplo, sigue las instrucciones de configuración de C++ que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API de C++ de Pub/Sub.
C#
Antes de probar este ejemplo, sigue las instrucciones de configuración de C# que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API de C# de Pub/Sub.
Go
En el siguiente ejemplo se usa la versión principal de la biblioteca de cliente de Pub/Sub de Go (v2). Si sigues usando la biblioteca v1, consulta la guía de migración a la versión 2. Para ver una lista de ejemplos de código de la versión 1, consulta los ejemplos de código obsoletos.
Antes de probar este ejemplo, sigue las instrucciones de configuración de Go que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API Go de Pub/Sub.
Java
Antes de probar este ejemplo, sigue las instrucciones de configuración de Java que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API de Java de Pub/Sub.
Node.js
Antes de probar este ejemplo, sigue las instrucciones de configuración de Node.js que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API de Node.js de Pub/Sub.
Node.ts
Antes de probar este ejemplo, sigue las instrucciones de configuración de Node.js que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API de Node.js de Pub/Sub.
PHP
Antes de probar este ejemplo, sigue las instrucciones de configuración de PHP que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API de Pub/Sub para PHP.
Python
Antes de probar este ejemplo, sigue las instrucciones de configuración de Python que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API de Python de Pub/Sub.
Ruby
En el siguiente ejemplo se usa la biblioteca de cliente de Ruby Pub/Sub v3. Si sigues usando la biblioteca v2, consulta la guía de migración a la versión 3. Para ver una lista de ejemplos de código de Ruby v2, consulta los ejemplos de código obsoletos.
Antes de probar este ejemplo, sigue las instrucciones de configuración de Ruby que se indican en la guía de inicio rápido sobre cómo usar bibliotecas de cliente. Para obtener más información, consulta la documentación de referencia de la API de Ruby de Pub/Sub.
El servicio Pub/Sub puede tardar varios minutos en separar la suscripción del tema.
Una vez que el servicio Pub/Sub desvincula la suscripción del tema, elimina los mensajes que conserva para la suscripción. No puedes recuperar estos mensajes de la suscripción ni volver a asociar la suscripción a un tema. Para liberar tu cuota de Google Cloud proyectos, elimina la suscripción.
Si la suscripción y el tema están en proyectos diferentes, el servicio Pub/Sub añade una entrada a los registros de auditoría de ambos proyectos. Google Cloud
Siguientes pasos
- Crea o modifica una suscripción con los comandos de
gcloud
. - Crea o modifica una suscripción con las APIs REST.