Ce guide explique comment configurer des filtres lorsque vous utilisez l'API Monitoring. Vous pouvez utiliser des filtres pour spécifier les ressources surveillées, les types de métriques et les séries temporelles.
Avant de commencer
Si vous ne connaissez pas bien les métriques, les séries temporelles et les ressources surveillées, consultez Métriques, séries temporelles et ressources.
Si vous ne connaissez pas le fonctionnement des libellés, consultez la section Libellés pour obtenir une présentation.
Utiliser des filtres
Vous pouvez utiliser des filtres dans l'API Monitoring pour effectuer les opérations suivantes :
- Sélectionner les données de séries temporelles spécifiques qui sont renvoyées par une requête API
list
. Le filtre peut sélectionner des séries temporelles en fonction des propriétés de ressource surveillée et des propriétés de métrique des données. Pour en savoir plus et obtenir des exemples, consultez la section Récupérer des données de séries temporelles.
Répertorier des types de métriques spécifiques. Pour obtenir plus d'informations et des exemples, consultez la section Répertorier les descripteurs de métriques.
Répertorier des types de ressources surveillées spécifiques. Pour obtenir plus d'informations et d'exemples, consultez la section Répertorier les descripteurs de ressources surveillées.
Sélecteurs de filtres
Un filtre comprend au moins un sélecteur, c'est-à-dire un mot clé de filtre. Les exemples suivants illustrent les différents sélecteurs :
-
resource
: renvoie les ressources surveillées d'un type particulier ou ayant des valeurs de libellé particulières.-
Le filtre suivant correspond à toutes les ressources surveillées qui sont des instances de machine virtuelle (VM) Compute Engine :
resource.type = "gce_instance"
-
-
metric
: renvoie un type de métrique ou une série temporelle spécifique avec un libellé particulier correspondant à une valeur spécifique.-
Le filtre suivant correspond à un type de métrique spécifique :
metric.type = "compute.googleapis.com/instance/cpu/usage_time"
-
Le filtre suivant correspond aux séries temporelles associées à un libellé nommé
instance_name
, dont la valeur commence pargke-hipster
ougke-nginx
:metric.labels.instance_name = monitoring.regex.full_match("gke-(hipster|nginx).*")
-
Le tableau suivant indique les sélecteurs autorisés dans les filtres en fonction de l'appel de l'API Monitoring :
Objectif du filtre | Sélecteur resource |
Sélecteur metric |
---|---|---|
Répertorier les séries temporelles | oui | Oui * |
Répertorier les descripteurs de statistiques | Oui | |
Répertorier les descripteurs de ressources surveillées | oui |
Les sections suivantes présentent des exemples d'utilisations courantes de filtres de surveillance. Pour en savoir plus sur les opérateurs et les objets de filtrage disponibles, consultez la section Syntaxe des filtres.
Récupérer des données de séries temporelles
Méthode :
projects.timeSeries.list
Objets de filtrage :
project
, resource.type
, resource.labels.[KEY]
, metric.type
,
metric.labels.[KEY]
Une série temporelle est une liste de points de données horodatés d'un type de métrique issus d'une ressource surveillée spécifique. Pour en savoir plus, consultez la section Modèle de métrique. Le type de métrique est spécifié par un descripteur de métrique, et la ressource surveillée est spécifiée par un descripteur de ressource surveillée.
Le filtre spécifié dans la méthode timeSeries.list
doit inclure un sélecteur metric
qui ne doit spécifier qu'un seul type de métrique :
- Pour renvoyer toutes les séries temporelles pour un type de métrique particulier :
metric.type = "compute.googleapis.com/instance/cpu/usage_time"
Pour renvoyer toutes les séries temporelles d'une instance Compute Engine spécifique, utilisez le filtre suivant :
metric.type = "compute.googleapis.com/instance/cpu/usage_time" AND metric.labels.instance_name = "my-instance-name"
Pour renvoyer toutes les séries temporelles issues d'instances Compute Engine dont le nom commence par
frontend-
, utilisez le filtre suivant :metric.type = "compute.googleapis.com/instance/cpu/usage_time" AND metric.labels.instance_name = starts_with("frontend-")
Pour renvoyer toutes les séries temporelles issues d'instances Compute Engine dont le nom commence par
gke-hipster
ougke-nginx
, utilisez le filtre suivant :metric.type = "compute.googleapis.com/instance/cpu/usage_time" AND metric.labels.instance_name = monitoring.regex.full_match("^gke-(hipster|nginx).*")
Répertorier les descripteurs de métriques
Méthode :
projects.metricDescriptors.list
Objets de filtrage : project
, metric.type
Utilisez un filtre pour limiter les descripteurs de métriques que vous récupérez.
Par exemple, pour ne renvoyer que les descripteurs de métrique Compute Engine, utilisez le filtre suivant :
metric.type = starts_with("compute.googleapis.com")
Pour obtenir la liste complète des types de métriques disponibles, consultez la liste des métriques. Pour en savoir plus sur le nommage des métriques, consultez Conventions de nommage des métriques.
Répertorier les descripteurs de ressources surveillées
Méthode :
projects.monitoredResourceDescriptors.list
Objets de filtrage : resource.type
Utilisez un filtre pour limiter les descripteurs de ressources surveillées que vous récupérez.
Par exemple, pour ne récupérer que les descripteurs de ressources surveillées par Pub/Sub, utilisez le filtre suivant :
resource.type = starts_with("pubsub")
Consultez la liste des ressources surveillées pour obtenir la liste complète des types de ressources surveillées définis par Monitoring.
Exemples
Dans les exemples de filtrage, nous utilisons le descripteur de métrique, le descripteur de ressource surveillée et l'instance de machine virtuelle suivants, qui ont été simplifiés pour l'illustration :
# Metric descriptor: { "name": "projects/my-project-id/metricDescriptors/compute.googleapis.com%2Finstance%2Fdisk%2Fread_bytes_count" "type": "compute.googleapis.com/instance/disk/read_bytes_count", "labels": [ { "key": "device_name", "description": "The name of the disk device." } ] } # Monitored resource descriptor: { "name": "monitoredResourceDescriptors/gce_instance" "type": "gce_instance", "labels": [ { "key": "instance_id", "description": "The instance ID provide by Google Compute Engine." }, { "key": "zone", "description": "The Google Cloud Platform zone hosting the instance." } ] } # Resource descriptor for a virtual machine instance. { "type": "gce_instance", "instance_id": "1472038649266883453", "zone": "us-east-1b", "disks": [ "log_partition" ], "machine_type": "n1-standard-2", "tags": { "environment": "bleeding-edge", "role": "frobulator" }, "project_id": "my-project-id" }
Exemples de récupération de métriques
Pour demander l'utilisation de la bande passante en lecture de disque pour toutes les instances et tous les appareils, définissez un filtre comme suit. Ce filtre renvoie, pour chaque instance, une série temporelle distincte indiquant la bande passante en lecture pour chaque appareil :
metric.type = "compute.googleapis.com/instance/disk/read_bytes_count"
Pour affiner la requête d'interrogation de la bande passante en lecture pour uniquement le disque appelé "log_partition" sur chaque instance, définissez le filtre comme suit. Ce filtre renvoie, pour chaque instance, une série temporelle au maximum, selon qu'un appareil de ce nom existe sur cette instance :
metric.type = "compute.googleapis.com/instance/disk/read_bytes_count" AND metric.labels.device_name = "log_partition"
Pour limiter la requête à une seule instance, spécifiez cette instance :
resource.type = "gce_instance" AND resource.labels.instance_id = "1472038649266883453" AND metric.type = "compute.googleapis.com/instance/disk/read_bytes_count" AND metric.labels.device_name = "log_partition"
Référence : syntaxe des filtres
Pour obtenir une présentation des filtres et des exemples, consultez la section Utiliser des filtres.
Un filtre de surveillance est une chaîne composée de deux types de sélecteurs au maximum :
<monitoring_filter> ::= <resource_selector> AND <metric_selector>
Le filtre correspond à un élément si tous les sélecteurs inclus correspondent à cet élément.
Comme décrit dans les sections suivantes, certains sélecteurs peuvent comporter plusieurs comparaisons jointes par AND
ou OR
. L'ordre des sélecteurs dans le filtre n'a pas d'importance, mais les comparaisons des différents sélecteurs ne doivent pas être mélangées.
Selon l'objectif du filtre, certains sélecteurs peuvent être obligatoires, facultatifs ou interdits. Par exemple, le filtre utilisé pour répertorier les séries temporelles doit contenir un sélecteur de métrique.
Comparaisons
Les filtres et leurs sélecteurs sont basés sur des comparaisons. Chaque comparaison se présente sous la forme suivante :
-
[OBJECT] : sélectionne une valeur à tester, parmi les suivantes :
metric.type metric.labels.[KEY] resource.type resource.labels.[KEY]
[KEY] est un nom, tel que
zone
ouinstance_id
.[KEYSTRING] peut être un nom, mais s'il contient des caractères spéciaux, il doit être placé entre guillemets (
"
). -
[OPERATOR] : un opérateur de comparaison, parmi les suivants :
= # equality (case-sensitive) > < >= <= # numeric ordering != # not equal : # "has" substring match and test for key (case-sensitive)
-
[VALUE] : une valeur littérale ou un appel de fonction intégré, parmi les suivants :
<string> # "a Unicode string". Don't use apostrophes (`'`) to quote strings. <bool> # true or false <number> # 0, -2, 123456, 3.14156 <function> # operators on the right side of '=' or '!=': # starts_with(<string>) # ends_with(<string>) # has_substring(<string> [, ignore_case=false]) # one_of(<string>,...,<string>) for up to 100 strings # monitoring.regex.full_match(<RE2-string>)
Sauf lorsqu'il est utilisé dans la méthode
timeSeries.list
, le filtrehas_substring
utilise un deuxième argument facultatif, qui spécifie si la correspondance ignore ou non la casse. La valeur par défaut estfalse
. La correspondance par défaut est donc sensible à la casse :- Sensible à la casse :
display_name=has_substring("Demo")
- Sensible à la casse :
display_name=has_substring("Demo", false)
- Non sensible à la casse :
display_name=has_substring("Demo", true)
Lorsqu'il est utilisé dans la méthode
timeSeries.list
, seul le formathas_substring(<string>)
est accepté.Le filtre
monitoring.regex.full_match
utilise une chaîne d'expression régulière dans la syntaxe RE2. - Sensible à la casse :
Vous pouvez utiliser les opérateurs suivants pour regrouper ou modifier des comparaisons. OR
a une priorité plus élevée que AND
. Les opérateurs doivent être écrits en majuscules :
(...) # grouping comparisons AND # conjunction (optional but recommended) OR # disjunction
L'opérateur AND
peut être omis entre les opérateurs, mais il est plus clair de l'inclure et cela réduit les erreurs.
La comparaison x = one_of("a", "b", "c")
équivaut à :
(x = "a" OR x = "b" OR x = "c")
Sélecteurs de filtres
Les sélecteurs vous permettent de limiter les sélections de filtres à certains éléments.
Dans les sections suivantes, les accolades sont utilisées pour afficher la répétition. Par exemple, la notation <x> {OR <y>}
signifie que vous pouvez écrire l'un des éléments suivants :
<x> <x> OR <y> <x> OR <y> OR <y> <x> OR <y> OR <y> OR <y> ...
Sélecteur de ressource
Un sélecteur de ressources limite la sélection du filtre aux ressources (ou aux éléments associés aux ressources) qui ont un type de ressource ou des valeurs de libellé spécifiques :
<resource_selector> ::= <resource_type_expression> | <resource_label_expression> | <resource_type_expression> AND <resource_label_expression> <resource_type_expression> ::= resource.type '=' <string> | resource.type ':' <string> | resource.type '=' starts_with '(' <string>')' | resource.type '=' ends_with '(' <string> ')' <r_label_comparison> ::= resource.labels.[KEY] '=' (<string> | <bool>) | resource.labels.[KEY] ':' <string> | resource.labels.[KEY] '=' (starts_with | ends_with) '(' <string> ')' | resource.labels.[KEY] ('=' | '>' | '<' | '>=' | '<=') <number> <resource_label_expression> ::= <r_label_comparison> {AND <r_label_comparison>} | <r_label_comparison> {OR <r_label_comparison>}
Si vous utilisez plusieurs <r_label_comparison>
dans votre sélecteur, placez-les entre parenthèses pour une meilleure lisibilité.
Sélecteur de métrique
Un sélecteur de métrique spécifie certaines métriques ou certains descripteurs de métriques en limitant le type de métrique et les libellés de métriques. Lorsqu'il est utilisé avec la méthode projects.timeSeries.list
, le sélecteur de métrique doit spécifier un seul type de métrique :
<metric_selector> ::= <metric_name_expression> [AND <metric_label_expression>] <metric_name_expression> ::= metric.type '=' <string> | metric.type ':' <string> | metric.type '=' starts_with '(' <string> ')' | metric.type '=' ends_with '(' <string> ')' <metric_label_comparison> ::= metric.labels.[KEY] '=' <string> | <bool> | metric.labels.[KEY] ':' <string> | metric.labels.[KEY] '=' starts_with '(' <string> ')' | metric.labels.[KEY] '=' ends_with '(' <string> ')' | metric.labels.[KEY] ('=' | '>' | '<' | '>=' | '<=') <number> <metric_label_expression> ::= <metric_label_comparison> {[AND] <metric_label_comparison>} | <metric_label_comparison> {OR <metric_label_comparison>}
Par exemple, le filtre suivant peut être utilisé afin de récupérer une série temporelle pour une instance de base de données spécifique :
metric.type = "cloudsql.googleapis.com/database/state" AND (metric.labels.resource_type = "instance" AND metric.labels.resource_id = "abc-123456")