Cette page explique comment émettre des métriques côté client gRPC vers Cloud Monitoring lorsque vous utilisez gRPC pour interagir avec Cloud Storage à l'aide de l'une des interfaces compatibles suivantes :
Bibliothèque cliente Java Cloud Storage, version 2.41.0 ou ultérieure
- Connecteur Apache Beam sur Dataflow, version 2.2.26 et ultérieure
Les métriques côté client peuvent être utilisées pour surveiller les performances de l'application cliente qui interagit avec Cloud Storage à l'aide de gRPC. La métrique côté client diffère des métriques côté serveur, qui fournissent des informations sur les performances de Cloud Storage du point de vue du serveur.
Fonctionnement
Vous pouvez choisir d'émettre des métriques côté client vers Cloud Monitoring lorsque vous utilisez gRPC pour interagir avec Cloud Storage à l'aide de l'une des interfaces compatibles. Vous pouvez afficher les métriques côté client à l'aide de l'explorateur de métriques pour vous aider à surveiller et à optimiser les interactions entre Cloud Storage et le client gRPC, à gérer l'utilisation, et à résoudre les problèmes de performances et techniques.
Tarifs
Les métriques côté client Cloud Storage ne sont pas facturables. Vous pouvez donc émettre, stocker et accéder à ces métriques sans encourir de frais Cloud Monitoring. Pour en savoir plus sur les tarifs, consultez la page Tarifs de Google Cloud Observability.
Avant de commencer
Pour utiliser des métriques côté client, vous devez d'abord effectuer les opérations suivantes :
Vérifiez que la bibliothèque cliente ou le connecteur Cloud Storage que vous souhaitez utiliser sont compatibles avec gRPC. Les bibliothèques clientes et connecteurs Cloud Storage suivants sont compatibles avec gRPC :
Activez l'API Cloud Monitoring.
Activez l'API Cloud Storage.
Définissez les rôles et autorisations requis pour émettre des métriques côté client.
Rôles requis
Pour définir les autorisations nécessaires à l'émission de métriques côté client gRPC vers Cloud Monitoring, accordez le rôle IAM Rédacteur de métriques Monitoring (roles/monitoring.metricWriter
) sur le compte de service utilisé par le client gRPC.
Ce rôle prédéfini contient les autorisations requises pour émettre des métriques côté client gRPC vers Cloud Monitoring. Pour connaître les autorisations exactes requises, consultez la section Autorisations requises :
Autorisations requises
monitoring.timeSeries.create
Vous pouvez également obtenir ces autorisations avec des rôles personnalisés ou d'autres rôles prédéfinis. Pour en savoir plus sur le rôle "Auteur de métriques Monitoring", consultez la documentation IAM concernant roles/monitoring.metricWriter
.
Remarques
Si vous utilisez le connecteur Cloud Storage sur Dataproc, vous devez accorder le rôle IAM Rédacteur de métriques Monitoring (
roles/monitoring.metricWriter
) au compte de service de la machine virtuelle (VM) Dataproc.Si vous utilisez le connecteur Apache Beam sur Dataflow, vous devez accorder le rôle IAM Rédacteur de métriques Monitoring (
roles/monitoring.metricWriter
) au compte de service de nœud de calcul Dataflow.
Afficher les métriques dans l'Explorateur de métriques
Suivez les instructions ci-dessous pour afficher les métriques côté client gRPC Cloud Storage dans l'explorateur de métriques.
Dans la console Google Cloud , accédez à la page Explorateur de métriques.
Sélectionnez le projet pour lequel vous souhaitez afficher les métriques.
Dans le menu déroulant Métrique, cliquez sur Sélectionner une métrique.
Dans la barre de recherche Filtrer par nom de ressource ou de métrique, saisissez
storage.googleapis.com/Client
ou recherchez la métrique que vous souhaitez appliquer par nom de métrique, puis cliquez sur Appliquer. Pour ajouter plusieurs métriques, cliquez sur Ajouter une requête.Cloud Storage applique les métriques à votre projet. Vous pouvez filtrer ou agréger vos métriques à l'aide des menus déroulants suivants :
Pour sélectionner et afficher un sous-ensemble de vos données en fonction de critères spécifiés, utilisez le menu déroulant Filtre.
Pour combiner plusieurs points de données en une seule valeur et afficher un récapitulatif de vos métriques, utilisez le menu déroulant Agrégation.
Laissez votre application s'exécuter pendant au moins une minute avant de rechercher des métriques publiées.
Pour afficher les métriques que vous avez ajoutées à votre projet à l'aide d'un tableau de bord, consultez Présentation des tableaux de bord.
Descriptions des métriques
Les sections suivantes décrivent les métriques côté client Cloud Storage qui peuvent être utilisées pour surveiller les performances du client gRPC.
Métriques par tentative côté client
Les métriques suivantes collectent des données de performances sur les tentatives individuelles effectuées par un client pour communiquer avec un serveur. Les métriques par tentative du client peuvent vous aider à mesurer le comportement de réessai et les goulots d'étranglement, et à optimiser la communication entre un client et un serveur.
Métrique complète | Description | Type d'instrument | Unité | Attributs |
---|---|---|---|---|
storage.googleapis.com/client/grpc/client/attempt/started |
Preview : nombre total de tentatives de RPC lancées, y compris celles qui ne sont pas terminées. |
Compteur | {attempt} |
|
storage.googleapis.com/client/grpc/client/attempt/duration |
Preview . Temps de bout en bout nécessaire pour effectuer une tentative RPC, y compris le temps nécessaire pour choisir un sous-canal. |
Histogramme | s |
|
storage.googleapis.com/client/grpc/client/attempt/sent_total_compressed_message_size |
Preview : nombre total d'octets compressés, mais non chiffrés, envoyés dans tous les messages de requête, à l'exception des métadonnées, par tentative de RPC. Cela n'inclut pas les octets de cadrage gRPC ni de transport. |
Histogramme | By |
|
storage.googleapis.com/client/grpc/client/attempt/rcvd_total_compressed_message_size |
Preview : nombre total d'octets (compressés, mais non chiffrés) reçus par tous les messages de réponse, à l'exception des métadonnées, par tentative de RPC. Cela n'inclut pas les octets de cadrage gRPC ni de transport. |
Histogramme | By |
|
Pour en savoir plus sur les instruments par tentative du client, consultez la documentation sur les métriques OpenTelemetry dans GitHub.
Métriques par appel côté client
Les métriques suivantes fournissent une vue agrégée de l'ensemble du cycle de vie d'un appel client à un serveur. Les métriques par appel client fournissent des données générales sur les appels client, des métriques de suivi pour comprendre les tendances des appels et vous aident à identifier la fréquence des erreurs.
Métrique complète | Description | Type d'instrument | Unité | Attributs |
---|---|---|---|---|
storage.googleapis.com/client/grpc/client/call/duration |
Preview . Mesure le temps de bout en bout nécessaire à la bibliothèque gRPC pour exécuter un RPC du point de vue de l'application. |
Histogramme | s |
|
Pour en savoir plus sur les instruments par appel client, consultez la documentation sur les métriques OpenTelemetry dans GitHub.
Métriques de détection de la charge des requêtes
Les métriques suivantes fournissent des informations sur l'efficacité de l'utilisation de la détection de la charge de requêtes par votre application cliente. Les métriques de détection de la charge des requêtes peuvent vous aider à équilibrer les charges du serveur, à optimiser l'utilisation des ressources et à améliorer les temps de réponse des clients. Les métriques suivantes ne sont disponibles qu'avec la connectivité directe.
Métrique complète | Description | Type d'instrument | Unité | Attributs |
---|---|---|---|---|
storage.googleapis.com/client/grpc/lb/rls/cache_entries |
Preview : nombre d'entrées dans le cache de détection de la charge de requêtes. |
Jauge | {entry} |
|
storage.googleapis.com/client/grpc/lb/rls/cache_size |
Preview : taille actuelle du cache de détection de la charge de requêtes. |
Jauge | By |
|
storage.googleapis.com/client/grpc/lb/rls/default_target_picks |
Preview : nombre de sélections d'équilibreur de charge envoyées à la cible par défaut. |
Compteur | {pick} |
|
storage.googleapis.com/client/grpc/lb/rls/target_picks |
Preview : nombre de sélections de LB envoyées à chaque cible de détection de charge de requête. Si la cible par défaut est également renvoyée par le serveur de détection de la charge de la requête, les RPC envoyés à cette cible à partir du cache sont comptabilisés dans cette métrique, et non dans grpc.rls.default_target_picks . |
Compteur | {pick} |
|
storage.googleapis.com/client/grpc/lb/rls/failed_picks |
Preview : nombre de sélections LB ayant échoué en raison d'une demande de détection de charge ayant échoué ou d'une limitation du canal de détection de charge des demandes. |
Compteur | {pick} |
|
Métriques du client du service xDiscovery
Les métriques suivantes fournissent des informations sur la façon dont votre application cliente interagit avec le plan de contrôle xDiscovery Service (xDS) pour découvrir et configurer les connexions aux services de backend. Les métriques xDS peuvent vous aider à suivre la latence des requêtes de service, à surveiller les mises à jour de configuration et à optimiser les performances globales de xDS.
Les métriques suivantes ne sont disponibles qu'avec la connectivité directe.
Métrique complète | Description | Type d'instrument | Unité | Attributs |
---|---|---|---|---|
storage.googleapis.com/client/grpc/xds_client/connected |
Preview . Indique si le client xDS dispose ou non d'un flux ADS fonctionnel vers le serveur xDS. Pour un serveur donné, cette métrique est définie sur 1 lorsque le flux est créé. En cas d'échec de la connectivité ou du flux ADS sans message de réponse conformément à A57 , la métrique est définie sur 0 . Une fois définie sur 0 , la métrique est réinitialisée sur 1 lorsque la première réponse est reçue sur un flux ADS. Cette métrique n'est disponible que pour les bibliothèques clientes Cloud pour C++. |
Jauge | {bool} |
|
storage.googleapis.com/client/grpc/xds_client/resource_updates_invalid |
Preview : nombre de ressources reçues considérées comme non valides. Cette métrique n'est disponible que pour les bibliothèques clientes Cloud pour C++. |
Compteur | {resource} |
|
storage.googleapis.com/client/grpc/xds_client/resource_updates_valid |
Preview : nombre de ressources reçues considérées comme valides, même si elles n'ont pas été modifiées.
Cette métrique n'est disponible que pour les bibliothèques clientes Cloud pour C++. |
Compteur | {resource} |
|
storage.googleapis.com/client/grpc/xds_client/resources |
Preview : nombre de ressources xDS. Cette métrique n'est disponible que pour les bibliothèques clientes Cloud pour C++. |
Jauge | {resource} |
|
storage.googleapis.com/client/grpc/xds_client/server_failure |
Preview . Nombre de serveurs xDS qui ne fonctionnent plus correctement et qui sont devenus indisponibles, surchargés ou qui fournissent des données de configuration incorrectes ou non valides. Cette métrique n'est disponible que pour les bibliothèques clientes Cloud pour C++. |
Compteur | {failure} |
|
Pour en savoir plus sur les métriques des clients xDS, consultez la documentation Équilibrage de charge mondial basé sur xDS sur GitHub.
Désactiver les métriques côté client
Si nécessaire, vous pouvez désactiver les métriques côté client.
Java
public GrpcStorageOptions.Builder setEnableGrpcClientMetrics(false enableGrpcClientMetrics)
Pour en savoir plus, consultez la méthode de classe GrpcStorageOptions.Builder
des bibliothèques clientes Cloud pour Java pour les métriques du client gRPC.
C++
Pour désactiver les métriques côté client pour l'API gRPC à l'aide des bibliothèques clientes Cloud pour C++, consultez Struct EnableGrpcMetricsOption
.
Si vous utilisez Bazel pour compiler votre application et que vous souhaitez désactiver les métriques côté client, définissez l'option enable_grpc_metrics
sur false
dans le fichier de compilation de votre application.
Étapes suivantes
En savoir plus sur l'observabilité dans Google Cloud
Découvrez comment ajouter des traces et des métriques personnalisées à votre application.