Después de crear una suscripción, puedes cambiar el método de entrega a push, pull o exportación.
Antes de empezar
- Crea una de las suscripciones admitidas.
Roles y permisos necesarios
Para obtener los permisos que necesitas para cambiar los tipos de suscripción y gestionarlos, 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 cambiar los tipos de suscripción y gestionarlos. Para ver los permisos exactos que se necesitan, despliega la sección Permisos necesarios:
Permisos obligatorios
Para cambiar los tipos de suscripción y gestionarlos, 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.
Modificar métodos de entrega
Puedes cambiar entre los distintos tipos de suscripción.
Consola
Para modificar una suscripción, sigue estos pasos.
- En la Google Cloud consola, ve a la página Suscripciones.
- Haz clic en more_vert junto a la suscripción que quieras actualizar.
- En Tipo de publicación, elige una opción de publicación.
- Rellena otras propiedades de la suscripción según sea necesario.
- Haz clic en Actualizar.
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 modificar la URL del endpoint de envío, ejecuta el comando
gcloud pubsub subscriptions modify-push-config
:gcloud pubsub subscriptions modify-push-config SUBSCRIPTION_ID \ --push-endpoint=PUSH_ENDPOINT
Si la suscripción ya usa la extracción, al definir el endpoint de inserción, se cambia el método de entrega a inserción.
Puedes cambiar de la entrega push a la pull cambiando el endpoint push a una cadena vacía.
- PROJECT_ID es el ID del proyecto.
- SUBSCRIPTION_ID es el ID de tu suscripción.
- PUSH_ENDPOINT es la URL modificada que quieres aplicar como tu nuevo endpoint de inserción. Por ejemplo,
https://myproject.appspot.com/myhandler
.
REST
Para modificar las configuraciones push de una suscripción, usa el método projects.subscriptions.modifyPushConfig
:
Solicitud:
La solicitud debe autenticarse con un token de acceso en el encabezado Authorization
. Para obtener un token de acceso de las credenciales predeterminadas de la aplicación actuales, usa gcloud auth application-default print-access-token
.
POST https://pubsub.googleapis.com/v1/projects/PROJECT_ID/subscriptions/SUBSCRIPTION_ID:modifyPushConfig Authorization: Bearer ACCESS_TOKEN
Cuerpo de la solicitud:
{ "pushConfig": { "pushEndpoint": "PUSH_ENDPOINT" } }
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.
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.
Siguientes pasos
- Crea o modifica una suscripción con los comandos de
gcloud
. - Crea o modifica una suscripción con las APIs REST.