En este documento, se describen los pasos para instrumentar un agente de LangGraph ReAct con OpenTelemetry, lo que permite recopilar telemetría del agente. Los mensajes del usuario, las respuestas y las elecciones del agente se incluyen en la telemetría como atributos adjuntos a los tramos. Las respuestas del agente también se incluyen en las entradas de registro que se correlacionan con los intervalos que contienen eventos de IA generativa. Las instrucciones de este documento se aplican cuando el agente usa ChatVertexAI de Langchain para llamar a un modelo de Gemini.
Instrumenta tu aplicación de IA generativa para recopilar telemetría
Para instrumentar tu aplicación de IA generativa y recopilar datos de registros, métricas y seguimiento, haz lo siguiente:
- Instala los paquetes de OpenTelemetry
- Configura OpenTelemetry para recopilar y enviar telemetría
- Haz un seguimiento de la invocación del agente de IA generativa
Instala los paquetes de OpenTelemetry
Agrega los siguientes paquetes de instrumentación y exportación de OpenTelemetry:
pip install 'opentelemetry-instrumentation-vertexai>=2.0b0' \
'opentelemetry-instrumentation-sqlite3' \
'opentelemetry-exporter-gcp-logging' \
'opentelemetry-exporter-gcp-monitoring' \
'opentelemetry-exporter-otlp-proto-grpc'
Los datos de registros y métricas se envían a tu proyecto Google Cloud a través de la API de Cloud Logging o la API de Cloud Monitoring. Las bibliotecas opentelemetry-exporter-gcp-logging
y opentelemetry-exporter-gcp-monitoring
invocan extremos en esas APIs.
Los datos de seguimiento se envían a Google Cloud con la API de Telemetry (OTLP), que admite el formato de OTLP.
Los datos que se reciben a través de este extremo también se almacenan en formato OTLP.
La biblioteca opentelemetry-exporter-otlp-proto-grpc
invoca el extremo de API de Telemetry (OTLP).
Configura OpenTelemetry para recopilar y enviar telemetría
Dentro del código de inicialización de tu agente de LangGraph, configura OpenTelemetry para capturar y enviar telemetría a tu proyecto Google Cloud :
Para ver la muestra completa, haz clic en more_vert Más y, luego, selecciona Ver en GitHub.
Haz un seguimiento de la invocación del agente de IA generativa
Para hacer un seguimiento de la ejecución de la invocación del agente de LangGraph, crea un intervalo personalizado alrededor de la invocación del agente:
Para ver la muestra completa, haz clic en more_vert Más y, luego, selecciona Ver en GitHub.
Es posible que desees incluir el código anterior en lugares clave del código de tu aplicación.
Para obtener más información sobre cómo agregar métricas y intervalos personalizados, consulta Agrega métricas y seguimientos personalizados a tu app.
Ejecuta la muestra
Esta muestra es un agente de LangGraph instrumentado con OpenTelemetry para enviar registros y seguimientos con instrucciones y respuestas de IA generativa, y métricas a tu proyecto deGoogle Cloud .
Personalidad del agente de LangGraph
El agente de LangGraph se define como un experto en SQL que tiene acceso completo a una base de datos SQLite efímera. El agente se implementa con el agente ReAct prediseñado de LangGraph y accede a la base de datos, que inicialmente está vacía, con SQLDatabaseToolkit.
Antes de comenzar
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
Install the Google Cloud CLI.
-
Si usas un proveedor de identidad externo (IdP), primero debes acceder a gcloud CLI con tu identidad federada.
-
Para inicializar gcloud CLI, ejecuta el siguiente comando:
gcloud init
-
Create or select a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator
), which contains theresourcemanager.projects.create
permission. Learn how to grant roles.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Vertex AI, Telemetry, Cloud Logging, Cloud Monitoring, and Cloud Trace APIs:
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin
), which contains theserviceusage.services.enable
permission. Learn how to grant roles.gcloud services enable aiplatform.googleapis.com
telemetry.googleapis.com logging.googleapis.com monitoring.googleapis.com cloudtrace.googleapis.com -
Install the Google Cloud CLI.
-
Si usas un proveedor de identidad externo (IdP), primero debes acceder a gcloud CLI con tu identidad federada.
-
Para inicializar gcloud CLI, ejecuta el siguiente comando:
gcloud init
-
Create or select a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator
), which contains theresourcemanager.projects.create
permission. Learn how to grant roles.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Vertex AI, Telemetry, Cloud Logging, Cloud Monitoring, and Cloud Trace APIs:
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin
), which contains theserviceusage.services.enable
permission. Learn how to grant roles.gcloud services enable aiplatform.googleapis.com
telemetry.googleapis.com logging.googleapis.com monitoring.googleapis.com cloudtrace.googleapis.com Si ejecutas la muestra en Cloud Shell, en recursos Google Cloudo en un entorno de desarrollo local, los permisos que se indican en esta sección son suficientes. En el caso de las aplicaciones de producción, por lo general, una cuenta de servicio proporciona las credenciales para escribir datos de registros, métricas y seguimientos.
Para obtener los permisos que necesitas para que la aplicación de ejemplo escriba datos de registros, métricas y seguimiento, pídele a tu administrador que te otorgue los siguientes roles de IAM en tu proyecto:
-
Escritor de registros de telemetría de Cloud (
roles/telemetry.tracesWriter
) -
Escritor de registros (
roles/logging.logWriter
) -
Escritor de métricas de Monitoring (
roles/monitoring.metricWriter
) -
Usuario de Vertex AI (
roles/aiplatform.user
)
-
Escritor de registros de telemetría de Cloud (
En Cloud Shell, ejecuta el siguiente comando:
git clone https://github.com/GoogleCloudPlatform/opentelemetry-operations-python.git
Ve al directorio de muestra:
cd opentelemetry-operations-python/samples/langgraph-sql-agent
Configure las variables de entorno:
# Capture GenAI prompts and responses export OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT=true # Capture application logs automatically export OTEL_PYTHON_LOGGING_AUTO_INSTRUMENTATION_ENABLED=true
Crea un entorno virtual y ejecuta la muestra:
python -m venv venv/ source venv/bin/activate pip install -r requirements.txt python main.py
La aplicación muestra un mensaje similar al siguiente:
Starting agent using ephemeral SQLite DB.
Para crear una base de datos, ingresa un valor en la instrucción Habla con el agente de SQL >> y, luego, presiona Intro.
Luego, las acciones que realiza el agente se muestran en Cloud Shell.
A continuación, se ilustran ejemplos de interacciones entre un usuario y la aplicación:
Talk to the SQL agent >> Create a new table to hold weather data. 👤 User: Create a new table to hold weather data. 🤖 Agent: I need to know what columns the table should have. What information about the weather do you want to store? For example, I could include columns for date, location, temperature, humidity, and precipitation. Talk to the SQL agent >> Create a new table to hold weather data. Include date, location, temperature, humidity, and precipitation. 👤 User: Create a new table to hold weather data. Include date, location, temperature, humidity, and precipitation. 🤖 Agent CREATE TABLE weather ( date DATE, location VARCHAR(255), temperature REAL, humidity REAL, precipitation REAL );
Para salir, ingresa
Ctrl-C
.-
Visor de registros (
roles/logging.viewer
) -
Visualizador de Monitoring (
roles/monitoring.viewer
) -
Usuario de Cloud Trace (
roles/cloudtrace.user
) -
En la consola de Google Cloud , ve a la página Explorador de seguimiento:
Ve al Explorador de seguimiento
También puedes usar la barra de búsqueda para encontrar esta página.
En la barra de herramientas, selecciona Agregar filtro, luego Nombre del tramo y, por último,
invoke agent
.La sección Ejecutar muestra incluía un ejemplo de ejecución en el que se enviaban dos instrucciones a la aplicación. En la siguiente imagen, se ilustra la página del Explorador de registros después de filtrar los datos:
Si nunca usaste Cloud Trace, Google Cloud Observability debe crear una base de datos para almacenar tus datos de seguimiento. La creación de la base de datos puede tardar unos minutos y, durante ese período, no habrá datos de seguimiento disponibles para ver.
Para explorar tus datos de registros y de intervalos, selecciona un intervalo en la tabla Intervalos.
Se abrirá la página Detalles. En esta página, se muestran el registro asociado y sus intervalos. En la tabla de la página, se muestra información detallada sobre el intervalo que seleccionaste. Esta información incluye lo siguiente:
En la pestaña GenAI, se muestran los eventos de los agentes de IA generativa. Para obtener más información sobre estos eventos, consulta Cómo ver eventos de IA generativa.
En la siguiente captura de pantalla, se ilustra un registro, en el que un intervalo tiene el nombre
invoke_agent
. Ese intervalo invoca a Gemini. El intervalo de Gemini incluye eventos de IA generativa:En la pestaña Registros y eventos, se enumeran las entradas de registro y los eventos asociados con el intervalo. Si deseas ver los datos de registro en el Explorador de registros, selecciona Ver registros en la barra de herramientas de esta pestaña.
Los datos de registro incluyen la respuesta del agente de LangGraph. Por ejemplo, para la ejecución de muestra, la carga útil de JSON incluye el siguiente contenido:
{ logName: "projects/my-project/logs/otel_python_inprocess_log_name_temp" jsonPayload: { finish_reason: "stop" message: { role: "model" content: [ 0: { text: "I need to know what columns the table should have. What information about the weather do you want to store? For example, I could include columns for date, location, temperature, humidity, and precipitation." } ] } index: 0 } ... }
Ejecuta la muestra
Para ejecutar la muestra, haz lo siguiente:
Las acciones que realizan los agentes de IA generativa no son determinísticas, por lo que es posible que veas una respuesta diferente para la misma instrucción.
Visualiza los registros, las métricas y los seguimientos
En esta sección, se describe cómo puedes ver los eventos de IA generativa.
Antes de comenzar
Para obtener los permisos que necesitas para ver tus datos de registros, métricas y seguimientos, pídele a tu administrador que te otorgue los siguientes roles de IAM en tu proyecto:
Para obtener más información sobre cómo otorgar roles, consulta Administra el acceso a proyectos, carpetas y organizaciones.
También puedes obtener los permisos necesarios a través de roles personalizados o cualquier otro rol predefinido.
Ver telemetría
Para ver los eventos de IA generativa, usa la página Explorador de seguimiento:
La muestra está instrumentada para enviar datos de métricas a tu proyecto de Google Cloud , pero no genera ninguna métrica.