Ce document explique comment instrumenter un agent IA créé avec le framework Agent Development Kit (ADK). Le framework ADK inclut une instrumentation OpenTelemetry qui collecte la télémétrie à partir des actions clés de l'agent. Lorsque vous activez l'instrumentation intégrée, elle envoie des informations telles que des requêtes textuelles et des réponses d'agent à votre Google Cloud projet. Ce document décrit les modifications requises et fournit un lien vers un exemple d'application.
Les applications qui utilisent ADK peuvent également collecter des requêtes et des réponses multimodales. Ce document explique comment collecter des requêtes et des réponses textuelles. Si vous souhaitez collecter des données multimodales, une configuration supplémentaire est requise. Pour en savoir plus, consultez Collecter et afficher des requêtes et des réponses multimodales.
L'observabilité par défaut fournie par ADK peut ne pas être suffisante pour le cas d'utilisation de votre application. Vous pouvez ajouter des bibliothèques d'instrumentation supplémentaires à l'aide d'OpenTelemetry pour capturer la télémétrie à partir d'autres parties de votre application, ou votre propre instrumentation personnalisée pour capturer des données spécifiques à l'application afin d'obtenir une observabilité plus précise. Par exemple, dans votre application, vous pouvez écrire du code d'instrumentation pour :
- suivre la consommation de ressources des outils appelés par l'agent ;
- suivre les échecs de validation spécifiques à l'application, les violations de règles métier ou les mécanismes personnalisés de récupération des erreurs ;
- suivre les scores de qualité des réponses de l'agent en fonction de vos critères spécifiques au domaine.
Instrumenter votre application d'IA générative pour collecter la télémétrie
Pour instrumenter votre agent IA afin de collecter des données de journal, de métrique et de trace, procédez comme suit :
Le reste de cette section décrit les étapes précédentes.
Installer les packages OpenTelemetry
Ajoutez les instrumentations et les packages d'exportation OpenTelemetry suivants :
pip install 'google-adk>=1.17.0' \
'opentelemetry-instrumentation-google-genai>=0.4b0' \
'opentelemetry-instrumentation-sqlite3' \
'opentelemetry-exporter-gcp-logging' \
'opentelemetry-exporter-gcp-monitoring' \
'opentelemetry-exporter-otlp-proto-grpc' \
'opentelemetry-instrumentation-vertexai>=2.0b0'
Les données de journal et de métrique sont envoyées à votre Google Cloud projet à l'aide de l'
API Cloud Logging ou de l'API Cloud Monitoring. Les
opentelemetry-exporter-gcp-logging et
opentelemetry-exporter-gcp-monitoring bibliothèques appellent
des points de terminaison dans ces API.
Les données de trace sont envoyées à Google Cloud l'aide de l'
API de télémétrie (OTLP), qui implémente le
protocole OpenTelemetry OTLP.
La bibliothèque opentelemetry-exporter-otlp-proto-grpc
appelle le point de terminaison de l'API de télémétrie (OTLP).
Vos données de trace sont stockées dans un format qui est généralement cohérent avec les fichiers proto définis par le protocole OpenTelemetry OTLP. Toutefois, les champs peuvent être convertis d'un type de données spécifique à OpenTelemetry en un type de données JSON avant le stockage. Pour en savoir plus sur le format de stockage, consultez Schéma des données de trace.
Configurer votre environnement ADK
Les versions 1.17.0 et ultérieures du framework ADK incluent une prise en charge intégrée d'OpenTelemetry et de l'envoi de données de télémétrie OpenTelemetry à Google Cloud Observability. Pour activer cette fonctionnalité, configurez votre environnement ADK :
Lorsque vous exécutez votre application avec la commande CLI
adk web, incluez le flag--otel_to_cloud.Dans votre fichier
opentelemetry.env, définissez les variables d'environnement suivantes :OTEL_SERVICE_NAME=adk-sql-agent OTEL_PYTHON_LOGGING_AUTO_INSTRUMENTATION_ENABLED=true OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT=trueNous vous recommandons également d'ajouter la variable d'environnement suivante à votre fichier
opentelemetry.env:ADK_CAPTURE_MESSAGE_CONTENT_IN_SPANS=falseCette variable d'environnement effectue les opérations suivantes :
- Empêche l'instrumentation ADK d'associer des attributs de segment qui dépassent la limite de taille des attributs.
- Empêche les informations permettant d'identifier personnellement l'utilisateur d'être associées aux segments en tant qu'attributs.
Télécharger et exécuter l'exemple d'application
Cet exemple de code implémente un agent d'IA générative créé à l'aide d'ADK. L'agent est instrumenté avec OpenTelemetry et configuré pour envoyer des métriques, des traces et des journaux à votre Google Cloud projet. La télémétrie envoyée à votre projet inclut des requêtes et des réponses d'IA générative.
Personnalité de l'agent ADK
L'agent d'IA générative est défini comme un expert SQL ayant un accès complet à une base de données SQLite éphémère. L'agent est créé avec l' Agent Development Kit et accède à une base de données à l'aide de SQLDatabaseToolkit. La base de données est initialement vide.
Avant de commencer
- Connectez-vous à votre Google Cloud compte. Si vous débutez sur Google Cloud, créez un compte pour évaluer les performances de nos produits en conditions réelles. Les nouveaux clients bénéficient également de 300 $de crédits sans frais pour exécuter, tester et déployer des charges de travail.
-
Installez la Google Cloud CLI.
-
Si vous utilisez un fournisseur d'identité (IdP) externe, vous devez d'abord vous connecter à la gcloud CLI avec votre identité fédérée.
-
Pour initialiser la gcloud CLI, exécutez la commande suivante :
gcloud init -
Créez ou sélectionnez un Google Cloud projet.
Rôles requis pour sélectionner ou créer un projet
- Sélectionner un projet : la sélection d'un projet ne nécessite pas de rôle IAM spécifique Vous pouvez sélectionner n'importe quel projet pour lequel un rôle vous a été attribué.
-
Créer un projet : pour créer un projet, vous avez besoin du rôle Créateur de projet
(
roles/resourcemanager.projectCreator), qui contient l'autorisationresourcemanager.projects.create. Découvrez comment attribuer des rôles.
-
Créez un Google Cloud projet :
gcloud projects create PROJECT_ID
Remplacez
PROJECT_IDpar un nom pour le Google Cloud projet que vous créez. -
Sélectionnez le Google Cloud projet que vous avez créé :
gcloud config set project PROJECT_ID
Remplacez
PROJECT_IDpar le nom de votre Google Cloud projet.
-
Vérifiez que la facturation est activée pour votre Google Cloud projet.
Activez les API Vertex AI, Télémétrie, Cloud Logging, Cloud Monitoring et Cloud Trace :
Rôles requis pour activer les API
Pour activer les API, vous avez besoin du rôle IAM Administrateur d'utilisation du service (
roles/serviceusage.serviceUsageAdmin), qui contient l'serviceusage.services.enableautorisation. Découvrez comment attribuer des rôles.gcloud services enable aiplatform.googleapis.com
telemetry.googleapis.com logging.googleapis.com monitoring.googleapis.com cloudtrace.googleapis.com -
Installez la Google Cloud CLI.
-
Si vous utilisez un fournisseur d'identité (IdP) externe, vous devez d'abord vous connecter à la gcloud CLI avec votre identité fédérée.
-
Pour initialiser la gcloud CLI, exécutez la commande suivante :
gcloud init -
Créez ou sélectionnez un Google Cloud projet.
Rôles requis pour sélectionner ou créer un projet
- Sélectionner un projet : la sélection d'un projet ne nécessite pas de rôle IAM spécifique Vous pouvez sélectionner n'importe quel projet pour lequel un rôle vous a été attribué.
-
Créer un projet : pour créer un projet, vous avez besoin du rôle Créateur de projet
(
roles/resourcemanager.projectCreator), qui contient l'autorisationresourcemanager.projects.create. Découvrez comment attribuer des rôles.
-
Créez un Google Cloud projet :
gcloud projects create PROJECT_ID
Remplacez
PROJECT_IDpar un nom pour le Google Cloud projet que vous créez. -
Sélectionnez le Google Cloud projet que vous avez créé :
gcloud config set project PROJECT_ID
Remplacez
PROJECT_IDpar le nom de votre Google Cloud projet.
-
Vérifiez que la facturation est activée pour votre Google Cloud projet.
Activez les API Vertex AI, Télémétrie, Cloud Logging, Cloud Monitoring et Cloud Trace :
Rôles requis pour activer les API
Pour activer les API, vous avez besoin du rôle IAM Administrateur d'utilisation du service (
roles/serviceusage.serviceUsageAdmin), qui contient l'serviceusage.services.enableautorisation. Découvrez comment attribuer des rôles.gcloud services enable aiplatform.googleapis.com
telemetry.googleapis.com logging.googleapis.com monitoring.googleapis.com cloudtrace.googleapis.com Si vous exécutez l'exemple dans Cloud Shell, sur Google Cloud des ressources ou dans un environnement de développement local, les autorisations listées dans cette section sont suffisantes. Pour les applications de production, un compte de service fournit généralement les identifiants permettant d'écrire des données de journal, de métrique et de trace.
Pour obtenir les autorisations nécessaires à l'exemple d'application afin d'écrire des données de journal, de métrique et de trace, demandez à votre administrateur de vous accorder les rôles IAM suivants sur votre projet :
-
Rédacteur de traces de télémétrie cloud (
roles/telemetry.tracesWriter) -
Rédacteur de journaux (
roles/logging.logWriter) -
Rédacteur de métriques Monitoring (
roles/monitoring.metricWriter) -
Utilisateur Vertex AI (
roles/aiplatform.user)
-
Rédacteur de traces de télémétrie cloud (
Lancer l'application
Pour lancer l'exemple d'application, procédez comme suit :
Dans Cloud Shell, exécutez la commande suivante :
git clone https://github.com/GoogleCloudPlatform/opentelemetry-operations-python.gitAccédez au répertoire de l'exemple :
cd opentelemetry-operations-python/samples/adk-sql-agentCréez un environnement virtuel et exécutez l'exemple :
python -m venv venv/ source venv/bin/activate pip install -r requirements.txt env $(cat opentelemetry.env | xargs) adk web --otel_to_cloudL'application affiche un message semblable à celui-ci :
Appplication startup complete Uvicorn running on http://0.0.0.0:8080Pour interagir avec l'agent, sélectionnez l'URL affichée dans le résultat de l'étape précédente.
Développez Sélectionner un agent , puis sélectionnez
sql_agentdans la liste des agents.
Interagir avec l'agent
Pour interagir avec l'agent, posez-lui une question ou donnez-lui une commande. Par exemple, vous pouvez poser la question suivante :
What can you do for me ?
De même, étant donné que sql_agent a la personnalité d'un expert SQL, vous pouvez lui demander de créer des tables pour vos applications et d'écrire des requêtes pour les utiliser. L'agent ne peut créer qu'une base de données éphémère sauvegardée par un fichier .db créé sur la machine exécutant l'application.
L'exemple suivant illustre une interaction entre sql_agent et l'utilisateur :
Les actions effectuées par les agents d'IA générative ne sont pas déterministes. Vous pouvez donc obtenir une réponse différente pour la même requête.
Quitter l'application
Pour quitter l'application, saisissez Ctrl-C dans l'interface système utilisée pour la lancer.
Afficher les traces, les métriques et les journaux
Cette section explique comment afficher les événements d'IA générative.
Avant de commencer
Pour obtenir les autorisations nécessaires pour afficher vos données de journal, de métrique et de trace, demandez à votre administrateur de vous accorder les rôles IAM suivants sur votre projet :
-
Lecteur de journaux (
roles/logging.viewer) -
Lecteur Monitoring (
roles/monitoring.viewer) -
Utilisateur Cloud Trace (
roles/cloudtrace.user)
Pour en savoir plus sur l'attribution de rôles, consultez Gérer l'accès aux projets, aux dossiers et aux organisations.
Vous pouvez également obtenir les autorisations requises avec des rôles personnalisés ou d'autres rôles prédéfinis.
Afficher la télémétrie
Pour afficher les événements d'IA générative créés par l'application, utilisez la page Explorateur Trace :
-
Dans la Google Cloud console, accédez à la
page Explorateur Trace :
Vous pouvez également accéder à cette page à l'aide de la barre de recherche.
Dans la barre d'outils, sélectionnez Ajouter un filtre, puis Nom du segment et enfin sélectionnez
call_llm.L'illustration suivante montre la page Explorateur Trace après le filtrage des données :
Si vous n'avez jamais utilisé Cloud Trace auparavant, Google Cloud Observability doit créer une base de données pour stocker vos données de trace. La création de la base de données peut prendre quelques minutes. Pendant cette période, aucune donnée de trace n'est disponible.
Pour explorer vos données de segment et de journal, sélectionnez un segment dans le tableau Segments.
La page Détails s'affiche. Cette page affiche la trace associée et ses segments. Le tableau de la page affiche des informations détaillées sur le segment que vous avez sélectionné. Voici quelques exemples :
L'onglet Entrées/Sorties affiche les événements des agents d'IA générative. Pour en savoir plus sur ces événements, consultez Afficher les événements d'IA générative.
La capture d'écran suivante illustre une trace dans laquelle un segment porte le nom
call_llm. Ce segment appelle le LLM (grand modèle de langage) qui alimente cet agent. Dans cet exemple, il s'agit de Gemini. Le segment Gemini inclut des événements d'IA générative :
L'onglet Journaux et événements liste les entrées de journal et les événements associés au segment. Si vous souhaitez afficher les données de journal dans l'explorateur de journaux, sélectionnez Afficher les journaux dans la barre d'outils de cet onglet.
Les données de journal incluent la réponse de
sql_agent. Par exemple, pour l'exemple d'exécution, la charge utile JSON inclut le contenu suivant :{ "logName": "projects/my-project/logs/otel_python_inprocess_log_name_temp", "jsonPayload": { "content": { "parts": [ 0: { "text": "Now I can create the table." } 1: {1} ], "role": "model" } }, ... }
L'exemple est instrumenté pour envoyer des données de métrique à votre Google Cloud projet, mais il ne génère aucune métrique.