Ce document explique comment exécuter le collecteur OpenTelemetry dans un cluster GKE pour collecter les journaux, les métriques et les traces OTLP à partir d'applications instrumentées, et exporter ces données vers Google Cloud.
Avant de commencer
L'exécution du collecteur OpenTelemetry sur GKE nécessite les ressources suivantes :
Un projet Google Cloud avec l'API Cloud Monitoring, l'API Cloud Trace et l'API Cloud Logging activées.
Si vous n'avez pas de projet Google Cloud, procédez comme suit :
Dans la console Google Cloud, accédez à Nouveau projet :
Dans le champ Nom du projet, saisissez un nom pour votre projet, puis cliquez sur Créer.
Accéder à la page Facturation :
Sélectionnez le projet que vous venez de créer s'il n'est pas déjà sélectionné en haut de la page.
Vous êtes invité à choisir un profil de paiement existant ou à en créer un.
L'API Monitoring, l'API Trace et l'API Logging sont activées par défaut pour les nouveaux projets.
Si vous disposez déjà d'un projet Google Cloud, assurez-vous que l'API Monitoring, l'API Trace et l'API Logging sont activées :
Accédez à la page API et services :
Sélectionnez votre projet.
Cliquez sur add Activer les API et les services.
Recherchez chaque API par nom.
Dans les résultats de recherche, cliquez sur l'API nommée. L'API Monitoring s'affiche sous le nom "API Stackdriver Monitoring".
Si l'option "API activée" ne s'affiche pas, cliquez sur le bouton Activer.
Un cluster Kubernetes. Si vous ne disposez pas de cluster Kubernetes, suivez les instructions du guide de démarrage rapide pour GKE.
Les outils de ligne de commande suivants :
gcloud
kubectl
Les outils
gcloud
etkubectl
font partie de Google Cloud CLI. Pour en savoir plus sur leur installation, consultez la page Gérer les composants de Google Cloud CLI. Pour afficher les composants de la CLI gcloud que vous avez installés, exécutez la commande suivante :gcloud components list
Déployer le collecteur
Le pipeline de collecteur peut être déployé directement à partir de GitHub avec les commandes suivantes, en remplaçant PROJECT_ID par l'ID de votre projet Google Cloud :
export GCLOUD_PROJECT=PROJECT_ID kubectl kustomize https://github.com/GoogleCloudPlatform/otlp-k8s-ingest.git/k8s/base | envsubst | kubectl apply -f -
Observer et déboguer le collecteur
Le collecteur OpenTelemetry fournit des métriques d'auto-observation prêtes à l'emploi pour vous aider à surveiller ses performances et à assurer la disponibilité continue du pipeline d'ingestion OTLP.
Pour surveiller le collecteur, installez l'exemple de tableau de bord pour le collecteur. Ce tableau de bord fournit des insights brefs sur plusieurs métriques du collecteur, y compris le temps d'activité, l'utilisation de la mémoire et les appels d'API vers Google Cloud Observability.
Pour installer le tableau de bord, procédez comme suit :
-
Dans la console Google Cloud, accédez à la page Tableaux de bord .
Accéder à la page Tableaux de bord
Si vous utilisez la barre de recherche pour trouver cette page, sélectionnez le résultat dont le sous-titre est Monitoring.
- Sélectionnez l'onglet Bibliothèque d'exemples.
- Sélectionnez la catégorie Collecteur OpenTelemetry.
- Sélectionnez le tableau de bord "Collecteur OpenTelemetry".
- Cliquez sur Importer.
Pour en savoir plus sur le processus d'installation, consultez Installer des exemples de tableaux de bord.
Configurer le collecteur
Le pipeline d'ingestion OTLP autogéré inclut une configuration par défaut du collecteur OpenTelemetry, conçue pour fournir de grands volumes de métriques, de journaux et de traces OTLP avec des métadonnées GKE et Kubernetes cohérentes. Il est également conçu pour éviter les problèmes d'ingestion courants.
Toutefois, vous pouvez avoir des besoins uniques qui nécessitent la personnalisation de la configuration par défaut. Cette section décrit les valeurs par défaut fournies avec le pipeline et comment les personnaliser en fonction de vos besoins.
La configuration du collecteur par défaut se trouve sur GitHub sous le nom config/collector.yaml
:
Exportateurs
Les exportateurs par défaut incluent l'exportateur googlecloud
(pour les journaux et les traces) et l'exportateur googlemanagedprometheus
(pour les métriques).
L'exportateur googlecloud
est configuré avec un nom de journal par défaut. L'exportateur googlemanagedprometheus
ne nécessite aucune configuration par défaut. Pour en savoir plus, consultez la section Premiers pas avec le collecteur OpenTelemetry dans la documentation Google Cloud Managed Service pour Prometheus.
Processeurs
La configuration par défaut inclut les processeurs suivants :
batch
: configuré pour regrouper des requêtes de télémétrie avec le nombre maximal d'entrées Google Cloud par requête, ou avec l'intervalle minimal Google Cloud de cinq secondes (selon ce qui survient en premier).k8sattributes
: mappe automatiquement les attributs de ressource Kubernetes aux étiquettes de télémétrie.memory_limiter
: limite l'utilisation de la mémoire du collecteur à un niveau raisonnable pour éviter les plantages dus à la mémoire saturée en supprimant des points de données au-delà de ce niveau.resourcedetection
: détecte automatiquement les étiquettes de ressources Google Cloud, comme le nom du cluster et l'ID du projet.transform
: renomme les étiquettes de métriques qui entreraient en conflit avec les champs de ressources surveillées par Google Cloud.
Récepteurs
La configuration par défaut n'inclut que le récepteur otlp
.
Pour obtenir des instructions détaillées sur l'instrumentation de vos applications afin d'envoyer des traces et des métriques OTLP au point de terminaison OTLP du collecteur, consultez Choisir une approche d'instrumentation.
Étapes suivantes : collecter et afficher les données de télémétrie
Cette section décrit comment déployer un exemple d'application, puis faire pointer cette application vers le point de terminaison OTLP du collecteur et afficher la télémétrie dans Google Cloud. L'application exemple est un petit générateur qui exporte des traces, des journaux et des métriques vers le collecteur.
Si vous disposez déjà d'une application instrumentée avec un SDK OpenTelemetry, vous pouvez plutôt la faire pointer vers le point de terminaison du collecteur.
Pour déployer l'exemple d'application, exécutez la commande suivante :
kubectl apply -f https://raw.githubusercontent.com/GoogleCloudPlatform/otlp-k8s-ingest/main/sample/app.yaml
Pour faire pointer des applications existantes qui utilisent le SDK OpenTelemetry vers le point de terminaison du collecteur, définissez la variable d'environnement OTEL_EXPORTER_OTLP_ENDPOINT
sur http://opentelemetry-collector.opentelemetry.svc.cluster.local:4317
.
Après quelques minutes, la télémétrie générée par l'application commence à circuler à travers le collecteur vers la console Google Cloud pour chaque signal.