Ce document explique comment créer des métriques définies par l'utilisateur et écrire ces données de métrique à l'aide de l'API Cloud Monitoring. Les métriques définies par l'utilisateur utilisent les mêmes éléments que les métriques Cloud Monitoring intégrées:
- Un ensemble de points de données
- Des informations sur les types de métriques, qui vous indiquent ce que les points de données représentent
- Les informations sur les ressources surveillées, qui indiquent l'origine des points de données
Les métriques définies par l'utilisateur, parfois appelées métriques personnalisées, peuvent être utilisées de la même manière que les métriques intégrées. Autrement dit, vous pouvez créer des graphiques et des alertes pour ces données de métriques.
Avant de commencer
Pour en savoir plus sur les structures sous-jacentes à toutes les métriques, consultez Métriques, séries temporelles et ressources.
Pour utiliser Cloud Monitoring, vous devez disposer d'un projet Google Cloud pour lequel la facturation est activée. Si nécessaire, procédez comme suit:
-
Dans Google Cloud Console, sur la page de sélection du projet, sélectionnez ou créez un projet Google Cloud.
-
Vérifiez que la facturation est activée pour votre projet Google Cloud. Découvrez comment vérifier si la facturation est activée sur un projet.
- Assurez-vous que l'API Monitoring est activée. Pour en savoir plus, consultez la page Activer l'API Monitoring.
Votre projet Google Cloud doit authentifier votre application pour les applications exécutées en dehors de Google Cloud. En règle générale, vous configurez l'authentification en créant un compte de service pour votre projet et en configurant une variable d'environnement.
Pour les applications que vous exécutez sur une instance Amazon Elastic Compute Cloud (Amazon EC2), créez le compte de service pour le projet de connecteur AWS de l'instance.
Pour en savoir plus sur la création d'un compte de service, consultez la page Premiers pas avec l'authentification.
Créer un type de métrique défini par l'utilisateur
Pour créer une métrique définie par l'utilisateur, vous devez définir un objet MetricDescriptor
qui spécifie différentes informations sur la métrique, ou vous devez écrire des données de métriques. Lorsque vous écrivez des données de métrique, Monitoring crée le descripteur de la métrique pour vous en fonction de la structure des données que vous fournissez.
Pour savoir comment concevoir un descripteur de la métrique, consultez Descripteurs de métriques pour les métriques définies par l'utilisateur.
Créer automatiquement des descripteurs de métrique
Si vous écrivez des données de métriques lorsqu'aucun descripteur de la métrique n'existe pour l'utilisateur, un descripteur de la métrique est créé automatiquement. Toutefois, ce nouveau descripteur pourrait ne pas ressembler exactement à ce que vous imaginiez. La création automatique de descripteurs de métrique implique certaines hypothèses et certains paramètres par défaut.
Cloud Monitoring crée un MetricDescriptor
lorsque l'objet TimeSeries
inclus dans un appel à timeSeries.create
fait référence à un objet Metric
qui spécifie un nom de type de métrique inexistant.
Cloud Monitoring utilise les règles suivantes pour renseigner le MetricDescriptor
:
type
: le type est copié à partir du champtype
de l'objetMetric
.name
: le nom est créé à partir de l'ID du projet dans l'appel de méthode et de la valeur detype
dans l'objetMetric
.labels
: libellés qui apparaissent dans l'objetMetric
. Chaque descripteur de libellé du nouveau descripteur de métrique comporte les champs suivants :key
: clé de libellé dans l'objetMetric
valueType
:STRING
description
: non défini
metricKind
: le genre de métrique est défini surGAUGE
, sauf si vous spécifiez le paramètremetricKind
de l'objetTimeSeries
. Lorsque vous spécifiezmetricKind
, la nouvelle métrique est du même type. Vous ne pouvez spécifier que les genresGAUGE
etCUMULATIVE
.valueType
: le type de valeur provient de la valeur saisie dePoint
. Le type de valeur doit êtreBOOL
,INT64
,DOUBLE
ouDISTRIBUTION
. Lorsque vous spécifiez un type de valeur dans le champvalueType
deTimeSeries
, ce type doit correspondre à celui dePoint
.unit
: non définidescription
:"Auto created custom metric."
.displayName
: non défini
Vous pouvez, dans un seul appel timeSeries.create
, inclure plusieurs objets TimeSeries
faisant référence au même type de métrique inexistant. Dans ce cas, les libellés du nouveau descripteur de la métrique consistent en l'union de tous les libellés des objets Metric
de toutes les séries temporelles de cet appel à create
.
Étape suivante: consultez la section Écrire des métriques définies par l'utilisateur.
Créer manuellement des descripteurs de métriques
Pour créer un descripteur de la métrique, procédez comme suit:
Déterminez la structure de votre descripteur de la métrique. Pour faire votre choix, vous pouvez parcourir les métriques intégrées et consulter leurs données de séries temporelles:
Choisissez un nom de métrique pour la métrique définie par l'utilisateur.
Choisissez le nom à afficher et la description de votre métrique. Le nom à afficher est utilisé dans la console Google Cloud.
Choisissez un ou plusieurs projets dans lesquels définir votre métrique définie par l'utilisateur et écrire ses données de séries temporelles. Lorsque vous avez besoin de la même métrique dans plusieurs projets, définissez des métriques identiques dans chaque projet.
Pour écrire des métriques définies par l'utilisateur à partir de ressources gérées par un compte AWS, créez le descripteur de la métrique dans le projet de connecteur AWS de ce compte.
Déterminez le type, le type de valeur et (facultatif) les unités de la métrique. Les types définis par l'utilisateur ne sont pas tous compatibles avec les types de valeurs et les genres de métriques. Pour en savoir plus sur ces champs, consultez la page Types de valeurs et genres de métriques.
Définissez les libellés de la métrique : noms, types de valeur et descriptions.
Déterminez les ressources surveillées sur lesquelles les données de métriques sont écrites. Sélectionnez l'une des options suivantes:
aws_ec2_instance
: instance Amazon EC2.dataflow_job
: tâche Dataflow.gae_instance
: instance App Engine.gce_instance
: instance Compute Engine.generic_node
: nœud de calcul spécifié par l'utilisateur.generic_task
: tâche définie par l'utilisateur.gke_container
: instance de conteneur GKE.global
: utilisez cette ressource lorsqu'aucun autre type de ressource ne convient. Dans la plupart des cas d'utilisation, il est préférable d'utilisergeneric_node
ougeneric_task
queglobal
.k8s_cluster
: cluster Kubernetesk8s_container
: conteneur Kubernetes.k8s_node
: nœud Kubernetesk8s_pod
: pod Kubernetes
Créez un objet
MetricDescriptor
, puis transmettez-le en tant qu'argument à un appel de la méthodemetricDescriptors.create
.
Appeler metricDescriptors.create
en utilisant le même nom de type qu'un descripteur de la métrique existant génère généralement une erreur. Notez qu'une erreur ne survient pas si tous les champs du nouvel objet MetricDescriptor
correspondent exactement aux champs du descripteur existant, mais l'appel n'a alors aucun effet.
Dans l'exemple suivant, vous créez une métrique jauge.
Protocole
Pour créer un descripteur de métrique, utilisez la méthode metricDescriptors.create
.
Vous pouvez exécuter cette méthode à l'aide du widget APIs Explorer sur la page de référence de la méthode. Pour en savoir plus, consultez la page APIs Explorer.
Voici des exemples de paramètres pour metricDescriptors.create
:
- name (URL) :
projects/[PROJECT_ID]
Corps de la requête : fournissez un objet
MetricDescriptor
tel que :{ "name": "", "description": "Daily sales records from all branch stores.", "displayName": "Sales", "type": "custom.googleapis.com/stores/sales", "metricKind": "CUMULATIVE", "valueType": "DOUBLE", "unit": "{USD}", "labels": [ { "key": "store_id", "valueType": "STRING", "description": "The ID of the store." }, ], }
Indiquez ces valeurs dans les champs du widget, en utilisant l'ID de votre projet à la place de [PROJECT_ID
] :
Cliquez sur le bouton Execute (Exécuter) pour exécuter la méthode.
Lorsque vous créez une métrique, le champ name
dans MetricDescriptor
est ignoré et peut être omis. La méthode create
affiche le nouveau descripteur de métrique avec le champ name
renseigné qui, dans cet exemple, se présente comme suit :
"name": "projects/[PROJECT_ID]/metricDescriptors/custom.googleapis.com/stores/daily_sales"
Par exemple, si vous souhaitez obtenir le descripteur d'une métrique, utilisez ce nom.
C#
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Go
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Java
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Node.js
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
PHP
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Python
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Ruby
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Consultez Résoudre les problèmes liés aux appels d'API en cas de problème.
Étape suivante: consultez la section Écrire des métriques définies par l'utilisateur.
Écrire des métriques définies par l'utilisateur
Vous ne pouvez écrire des données que dans les types de métriques définis par l'utilisateur. Pour écrire vos données, utilisez la méthode timeSeries.create
.
Lorsque la série temporelle existe, cette méthode ajoute un nouveau point de données à la série temporelle existante. Lorsque la série temporelle n'existe pas, cette méthode la crée et ajoute les données.
Vous pouvez écrire des points de données en spécifiant une liste d'objets TimeSeries
avec la méthode timeSeries.create
.
La taille maximale de la liste est de 200 objets, et chacun doit spécifier une série temporelle différente :
- Les valeurs des champs
metric
etresource
identifient un objetTimeSeries
spécifique. Ces champs représentent le type de métrique des données et la ressource surveillée à partir de laquelle les données ont été collectées. - Il est inutile de renseigner les champs
metricKind
etvalueType
, car ils sont ignorés lors de l'écriture des points de données. Chaque objet
TimeSeries
ne doit contenir qu'un seul objetPoint
:- La valeur et l'intervalle de temps spécifiés pour le point doivent être cohérents avec la définition du type de métrique. Pour en savoir plus sur les intervalles de temps correspondant aux différents genres de métriques, consultez la page
TimeInterval
. - L'intervalle de temps du point doit être ultérieur à tout point déjà présent dans la série temporelle.
- L'heure de fin de l'intervalle ne doit pas aller au-delà de 25 heures dans le passé ou de 5 minutes dans le futur.
- La valeur et l'intervalle de temps spécifiés pour le point doivent être cohérents avec la définition du type de métrique. Pour en savoir plus sur les intervalles de temps correspondant aux différents genres de métriques, consultez la page
Pour écrire plusieurs points sur la même série temporelle, utilisez un appel distinct à la méthode
timeSeries.create
pour chaque point. N'écrivez pas de données dans une série temporelle unique plus rapidement qu'un point pour chaque tranche de 5 secondes. Lorsque vous ajoutez des points de données à différentes séries temporelles, aucune limitation du débit n'est appliquée.
Protocole
Pour écrire des données de métrique, utilisez la méthode timeSeries.create
.
Vous pouvez exécuter cette méthode à l'aide du widget APIs Explorer sur la page de référence de la méthode. Pour en savoir plus, consultez la page APIs Explorer.
Pour écrire un point sur la métrique stores/daily_sales
créée dans la section Créer manuellement des descripteurs de métrique:
- Accédez à la page de référence sur
timeSeries.create
. - Indiquez les paramètres ci-dessous au widget APIs Explorer.
- Cliquez sur le bouton Execute (Exécuter).
Utilisez les exemples de paramètres suivants :
- name :
projects/[PROJECT_ID]
Corps de la requête : inclut une liste d'objets
TimeSeries
. L'exemple suivant ne comporte qu'une seule série temporelle.{ "timeSeries": [ { "metric": { "type": "custom.googleapis.com/my_metric", "labels": { "my_label": "my_value" } }, "resource": { "type": "gce_instance", "labels": { "project_id": "[PROJECT_ID]", "instance_id": "1234567890123456789", "zone": "us-central1-f" } }, "points": [ { "interval": { "endTime": "2018-06-01T10:00:00-04:00" }, "value": { "doubleValue": 123.45 } } ] } ] }
C#
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Go
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Java
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Node.js
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
PHP
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Python
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Ruby
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Consultez Résoudre les problèmes liés aux appels d'API en cas de problème.
Supprimer des métriques définies par l'utilisateur
Pour supprimer une métrique définie par l'utilisateur, supprimez son descripteur de la métrique. Vous ne pouvez pas supprimer les données de séries temporelles stockées dans votre projet Google Cloud. Toutefois, la suppression du descripteur de métrique les rend inaccessibles. Les données ont un délai d'expiration et sont supprimées conformément à la règle de conservation des données.
Vous ne pouvez pas supprimer le descripteur d'une métrique intégrée.
Pour supprimer votre descripteur de la métrique, appelez la méthode metricDescriptors.delete
.
Protocole
Pour supprimer un descripteur de métrique, utilisez la méthode metricDescriptors.delete
.
Vous pouvez exécuter cette méthode à l'aide du widget APIs Explorer sur la page de référence de la méthode. Pour en savoir plus, consultez la page APIs Explorer.
Pour supprimer la métrique stores/daily_sales
créée dans la section Créer manuellement des descripteurs de métrique:
- Accédez à la page de référence sur
metricDescriptors.delete
: Indiquez le nom du descripteur de métrique dans le widget APIs Explorer :
name :
projects/[PROJECT_ID]/metricDescriptors/custom.googleapis.com/stores/daily_sales
Cliquez sur le bouton Execute (Exécuter).
C#
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Go
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Java
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Node.js
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
PHP
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Python
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Ruby
Pour vous authentifier auprès de Monitoring, configurez les identifiants par défaut de l'application. Pour en savoir plus, consultez la page Configurer l'authentification pour un environnement de développement local.
Consultez Résoudre les problèmes liés aux appels d'API en cas de problème.
Modifier une métrique définie par l'utilisateur
Pour modifier une métrique définie par l'utilisateur, vous devez mettre à jour l'objet MetricDescriptor
qui la définit.
La seule modification possible est l'ajout de libellés.
Pour ajouter des libellés à une métrique définie par l'utilisateur existante, utilisez la méthode timeSeries.create
et ajoutez les nouveaux libellés aux données de séries temporelles. Les étiquettes sont ajoutées au descripteur de la métrique lorsque les étiquettes que vous tentez d'écrire sont valides et que le nombre total d'étiquettes est inférieur à 30.
Les données de séries temporelles sont ensuite écrites comme si le libellé était présent depuis le début.
Si vous souhaitez effectuer autre chose que ajouter des étiquettes, vous devez supprimer et recréer le descripteur de la métrique. Dans ce cas, vous perdez l'ensemble des données de séries temporelles précédemment collectées pour l'ancien descripteur de métrique. Pour en savoir plus, consultez la section Supprimer des métriques définies par l'utilisateur.
Vous ne pouvez pas renommer une métrique.
Étapes suivantes
- Afficher les diagnostics des métriques
- Liste des métriques intégrées
- Liste des ressources surveillées