¿Qué deberías usar: el agente de Logging o la biblioteca cliente?

En este documento, se proporciona la información que necesitas para decidir si enviar de manera programática registros de aplicaciones a Cloud Logging mediante bibliotecas cliente o un agente de Logging. Los agentes de Logging envían datos escritos en un archivo, como stdout o un archivo, como registros a Cloud Logging. Los servicios como Google Kubernetes Engine, el entorno flexible de App Engine y Cloud Functions contienen un agente de registros integrado. En Compute Engine, puedes instalar el agente de operaciones o el agente de Cloud Logging heredado. Estos agentes recopilan registros de ubicaciones de archivos o servicios de registro conocidos, como Windows Event Log, journald o syslogd.

Cuando no puedes usar una biblioteca cliente o un agente de Logging, o cuando solo quieres experimentar, puedes escribir registros con el comando gcloud logging write o enviando comandos HTTP al extremo de API de Cloud Logging entries.write. La API de Cloud Logging admite llamadas HTTP y gRPC. El Agente de operaciones y la mayoría de las bibliotecas cliente de Logging llaman a la API de Logging de gRPC. El agente de Logging heredado y las bibliotecas cliente para algunos lenguajes llaman a la API de REST de Logging.

Elige un agente o bibliotecas cliente

Cuando decidas entre un agente o las bibliotecas cliente, ten en cuenta las siguientes preguntas:

¿La aplicación se ejecuta fuera de Google Cloud?

Si tu aplicación no se ejecuta en Google Cloud, necesitas alguna forma de enviar registros a la API de Logging. Para enrutar los registros de los sistemas locales a Logging, te recomendamos que uses BindPlane de observIQ. Para obtener más información sobre BindPlane, consulta Acerca de observIQ y BindPlane.

Como alternativa, puedes enrutar los registros a Logging directamente desde la aplicación mediante las bibliotecas cliente. Para entornos efímeros, como la computación sin servidores, debes usar las bibliotecas cliente a fin de realizar llamadas directas a la API de Logging.

¿El servicio de Google Cloud que ejecuta tu aplicación es compatible
escribes el contenido de stdout y stderr en tu proyecto?

Algunos servicios de Google Cloud están completamente administrados, por lo que no necesitas usar agentes para enviar registros a tu proyecto de Google Cloud. Puedes usar cualquier framework de registro establecido en el lenguaje que elijas, como Go, Node.js y Python, para enviar registros a Logging en los productos en los que stdout y stderr son compatibles de forma predeterminada. Una ventaja de depender de stdout y stderr en lugar de usar las bibliotecas cliente es que las fallas de la aplicación no interrumpen el envío de registros a tu proyecto. Para obtener información sobre el envío de registros estructurados a través de stdout y stderr, consulta la sección ¿Tu aplicación tiene la flexibilidad de cambiar el formato de registro?.

Puedes usar las bibliotecas cliente de Logging, pero ten en cuenta que puede ingresar una dependencia en Logging para las pruebas locales, cuando no la necesites. El uso de las bibliotecas cliente también puede requerir una programación más compleja para controlar de forma explícita el almacenamiento en búfer y los reintentos. Además, cada uso de las bibliotecas cliente de Logging crea un flujo de conexión nuevo a la API. Estas conexiones nuevas presentan mayor complejidad, usan puertos adicionales y envían solicitudes separadas solo con los registros de la aplicación, lo que podría ser un desperdicio si no hay muchos registros.

¿Los registros de la aplicación deben ser accesibles en tu entorno local?

Si necesitas acceder a los registros de la aplicación en tu entorno local para la depuración y otros fines, puedes usar los módulos de registro en algunos lenguajes a fin de generar los resultados en stdout y stderr. Las bibliotecas cliente de Logging para algunos lenguajes admiten el enrutamiento de registros a stdout y stderr.

Cuando ejecutas tu aplicación en los servicios de Google Cloud que no admiten el envío automático de los registros escritos en stdout y stderr a tu proyecto de Google Cloud, puedes recopilar registros de stdout y stderr en archivos en el disco y configurar el agente para que los recopile y los envíe a Logging. Para obtener más información, consulta la guía de configuración del Agente de operaciones o el agente de Logging heredado.

¿El proceso de instalación del agente es manual o automático?

Algunos servicios instalan agentes de forma automática o te permiten instalarlos. Si el servicio que usas no te permite instalar agentes, debes usar las bibliotecas cliente para usar Logging.

¿Ya ejecutas Fluentd en tu sistema?

El agente de Logging heredado se basa en Fluentd.

Si ya tienes Fluentd en ejecución en tu sistema y deseas usar ese daemon a fin de enviar tus registros a Logging, usa el complemento de Google Cloud Logging para fluentd.

¿También recopilas métricas de aplicaciones para Cloud Monitoring?

En las VM de Compute Engine, el agente de operaciones puede recopilar registros y la mayoría de las métricas. Consulta las funciones del agente de operaciones para obtener más información.

Si el agente de operaciones no aborda tus casos de uso, puedes usar el agente de Monitoring heredado o las bibliotecas cliente de Monitoring para recopilar tus métricas.

¿Tu aplicación tiene la flexibilidad de cambiar el formato de registro?

Esta pregunta te ayuda a decidir si tu aplicación puede generar registros estructurados. Logging reconoce registros estructurados si envías los registros a la API de Logging en el formato de registro estructurado. Las bibliotecas cliente proporcionan los métodos para manejar este formato.

Existen dos formas de escribir registros estructurados: una es establecer campos específicos en el sobre de LogEntry y la otra es configurar jsonPayload dentro del sobre de LogEntry. Cloud Logging determina el esquema para lo primero, mientras que el usuario determina el esquema para el último.

Debes configurar el agente para que reconozca los registros estructurados. De forma predeterminada, los agentes se configuran para detectar registros en formato JSON y controlarlos como registros estructurados. Si tu aplicación tiene su propio formato de registro que no puedes cambiar, pero deseas que los registros se reconozcan como registros estructurados, debes escribir los registros en el formato structured-logging, por lo general, JSON, en stdout y stderr, para que los agentes puedan reconocerlos como registros estructurados. De lo contrario, debes configurar el agente para que comprenda tu propio formato.

Resumen de cada opción

Diagrama de patrones de registro

  • Bibliotecas cliente de Cloud Logging

    • Ventajas

      • Puedes enrutar registros directamente a la API de Cloud Logging.
      • Algunos lenguajes pueden generar registros en stdout y stderr mediante la biblioteca.
    • Desventajas

      • Las fallas de la aplicación interrumpen el envío de registros a tu proyecto de Google Cloud.
  • Agente de operaciones

    • Ventajas
      • El Agente de operaciones puede enviar registros y métricas mediante tecnologías de código abierto estables: Fluent Bit para la recopilación de registros y OpenTelemetry Collector para la recopilación de métricas.
      • Puedes recopilar registros y métricas de muchas aplicaciones comunes. Consulta Supervisa y recopila registros de aplicaciones de terceros.
      • Puedes conservar registros en tu entorno local.
      • Es posible que puedas recuperar registros de fallas de la aplicación.
      • El Agente de operaciones está en desarrollo activo.
  • Agente de Logging heredado

    • Ventajas
      • El agente usa Fluentd para recopilar registros.
      • Puedes conservar registros en tu entorno local.
      • Es posible que puedas recuperar registros de fallas de la aplicación.
    • Desventajas
      • El agente es compatible actualmente, pero no está en desarrollo activo.
  • Los registros de stdout y stderr se envían automáticamente a tu proyecto de Google Cloud

    • Ventajas
      • Este proceso es una forma común de emitir registros a entornos locales.
      • Puedes usar bibliotecas de registro arbitrarias.
      • Es posible que puedas recuperar registros de fallas de la aplicación.
    • Desventajas
      • No todos los entornos enrutan los registros a Logging automáticamente.