Puedes usar un activador de Eventarc para ejecutar un flujo de trabajo como resultado de un evento o un conjunto de eventos. Los eventos se enrutan desde un proveedor de eventos a los receptores de eventos interesados.
Eventarc entrega eventos al receptor de eventos en el formato de CloudEvents a través de una solicitud HTTP. El servicio de Workflows convierte la a un objeto JSON (siguiendo el Especificación de CloudEvents) y pasa el evento a la ejecución del flujo de trabajo como un argumento de tiempo de ejecución del flujo de trabajo.
Se activa una ejecución de tu flujo de trabajo:
- Cuando se crea un registro de auditoría que coincide con los criterios de filtro del activador. Por ejemplo, consulta esta guía de inicio rápido para activar Workflows con eventos de BigQuery con Registros de auditoría de Cloud.
- En respuesta a eventos directos, como una actualización de un bucket de Cloud Storage o una actualización de una plantilla de Firebase Remote Config. Por ejemplo, consulta esta guía de inicio rápido, en la que activarás Workflows con las funciones directas desde Cloud Storage.
- Por mensajes publicados en un tema de Pub/Sub Por ejemplo, consulta esta guía de inicio rápido en la que activas flujos de trabajo con mensajes de Pub/Sub.
Ten en cuenta lo siguiente:
Los eventos se consideran entregados en cuanto comienza la ejecución del flujo de trabajo, y la ejecución real se realiza de forma asíncrona en los servicios de Workflows.
Las ejecuciones activadas por eventos no se reintentan si la ejecución del flujo de trabajo se inicia, pero luego falla. Para obtener más información, consulta la Política de reintento de eventos.
La ventana de anulación de duplicación de Workflows para garantizar el seguimiento “exactamente una vez” el procesamiento de eventos es de 24 horas.
Cuando usas Workflows como destino de un Activador de Eventarc, eventos superiores al máximo El tamaño del argumento de Workflows no activará las ejecuciones de flujos de trabajo. Para obtener más información, consulta Cuotas y límites.
En proyectos protegidos por un perímetro de servicio, cuando enrutas eventos a destinos de Workflows para los que el extremo de envío de Pub/Sub está configurado en una ejecución de Workflows, solo puedes crear suscripciones de envío de Pub/Sub nuevas mediante Eventarc. Ten en cuenta que la cuenta de servicio que se usa para la autenticación de envío para el extremo de Workflows debe incluirse en el perímetro de servicio. Para obtener más información, consulta Configura un perímetro de servicio con los Controles del servicio de VPC.
Crear un activador mediante Google Cloud CLI
Para crear un activador, ejecuta un comando gcloud eventarc triggers create
junto con las marcas obligatorias y opcionales.
Para obtener más información, consulta las instrucciones de gcloud en la sección “Crea un activador" cuando crear un activador para un proveedor, un tipo de evento y Workflows específicos.
Crear un activador mediante Console
En los siguientes pasos, se muestra cómo crear un activador en la página Workflows de la consola de Google Cloud.
Antes de comenzar
-
Enable the Eventarc and Pub/Sub APIs.
Crear una cuenta de servicio para que Eventarc pueda realizar solicitudes a la API de Workflows:
En la consola de Google Cloud, ve a la página Cuentas de servicio.
Selecciona un proyecto y haz clic en Crear cuenta de servicio.
En el campo Nombre de la cuenta de servicio, ingresa un nombre que esté entre 6 y 30 caracteres.
Puede contener guiones y caracteres alfanuméricos en minúscula. Después de crear una cuenta de servicio, no podrás cambiar su nombre.
Haz clic en Crear y continuar.
Otorga a tu nueva cuenta de servicio workflows.invoker para que tiene permiso para activar tu flujo de trabajo. En la lista Seleccionar un rol, selecciona Workflows > Workflows Invoker.
Si desarrollas una app de producción, siempre otorga los roles menos permisivos posibles. Para obtener más información, consulta Administra el acceso a proyectos, carpetas y organizaciones.
Haz clic en Listo.
Para permitir que la principal que ejecutará tus comandos de Eventarc pueda actuar como una cuenta de servicio de Identity and Access Management (IAM), otorga un rol que le permita a la principal suplantar la identidad de la cuenta de servicio.
Configura el activador
Si aún no tienes un flujo de trabajo que quieras activar, crea y, luego, impleméntalo.
En la consola de Google Cloud, ve a la página Workflows.
En la página Workflows, selecciona un flujo de trabajo para ir a sus detalles. .
En la página Detalles del flujo de trabajo, haz clic en edit Editar.
En la página Editar flujo de trabajo, selecciona Agregar activador nuevo > Eventarc.
Se abrirá el panel Evento de Eventarc.
Sigue las instrucciones para crear un activador para un proveedor, un tipo de evento y un destinoWorkflows específicos y consulta las instrucciones de la consola en la sección “Crea un activador”.
Selecciona la Cuenta de servicio que invoca tu flujo de trabajo.
Esto especifica la cuenta de servicio de IAM a la que se le otorgó previamente el rol
workflows.invoker
para que la cuenta tenga permiso para activar tu flujo de trabajo.Haz clic en Guardar activador.
El activador de Eventarc aparece en la lista de Activadores de la página Detalles de flujos de trabajo.
Si quieres actualizar o borrar el activador, debes editar el flujo de trabajo:
- En la página Detalles del flujo de trabajo, haz clic en edit Editar.
- En la sección Activadores, busca el activador que deseas actualizar o borrar.
- Haz clic en edit Editar recurso. delete Borrar recurso.
La ejecución de tu flujo de trabajo ahora se activa con los eventos que coinciden con la prioridad de tu activador. criterios de filtro.
Crea un activador con Terraform
Puedes crear un activador para un flujo de trabajo con Terraform. Para obtener más detalles, consulta Activa un flujo de trabajo con Eventarc y Terraform.