Ce document contient des exemples de requêtes spécifiques aux données de trace stockées dans votre projet Google Cloud .
Prise en charge du langage SQL
Les requêtes utilisées sur la page Observability Analytics sont compatibles avec les fonctions GoogleSQL, à quelques exceptions près.
Les commandes SQL suivantes ne sont pas acceptées pour les requêtes SQL émises à l'aide de la page Observability Analytics :
- Commandes LDD et LMD
- Fonctions JavaScript définies par l'utilisateur
- Fonctions BigQuery ML
- Variables SQL
Les éléments suivants ne sont compatibles que lorsque vous interrogez un ensemble de données associé à l'aide des pages BigQuery Studio et Looker Studio, ou à l'aide de l'outil de ligne de commande bq :
- Fonctions JavaScript définies par l'utilisateur
- Fonctions BigQuery ML
- Variables SQL
Bonnes pratiques
Pour définir la période de votre requête, nous vous recommandons d'utiliser le sélecteur de période. Par exemple, pour afficher les données de la semaine dernière, sélectionnez Les 7 derniers jours dans le sélecteur de période. Vous pouvez également utiliser le sélecteur de période pour spécifier une heure de début et de fin, une heure à afficher et un fuseau horaire.
Si vous incluez un champ start_time dans la clause WHERE, le paramètre du sélecteur de période n'est pas utilisé. L'exemple suivant montre comment filtrer par code temporel :
-- Matches trace spans whose start_time is within the most recent 1 hour. WHERE start_time > TIMESTAMP_SUB(CURRENT_TIMESTAMP(), INTERVAL 1 HOUR)
Pour savoir comment filtrer par heure, consultez Fonctions temporelles et Fonctions d'horodatage.
Avant de commencer
- Connectez-vous à votre compte Google Cloud . 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.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
Enable the Observability API.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
Enable the Observability API.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.-
Pour obtenir les autorisations nécessaires pour charger la page Analytics d'observabilité, écrire, exécuter et enregistrer des requêtes privées sur vos données de trace, demandez à votre administrateur de vous accorder les rôles IAM suivants :
- Accesseur de vue d'observabilité (
roles/observability.viewAccessor) sur les vues d'observabilité que vous souhaitez interroger. Ce rôle est compatible avec les conditions IAM, qui vous permettent de limiter l'accès à une vue spécifique. Si vous n'associez pas de condition à l'attribution de rôle, le compte principal peut accéder à toutes les vues d'observabilité. - Utilisateur Observability Analytics (
roles/observability.analyticsUser) sur votre projet Ce rôle contient les autorisations requises pour enregistrer et exécuter des requêtes privées, et pour exécuter des requêtes partagées. - Lecteur de journaux (
roles/logging.viewer) sur votre projet.
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.
- Accesseur de vue d'observabilité (
Utiliser les requêtes sur cette page
-
Dans la console Google Cloud , accédez à la page manage_search Analyse de l'observabilité :
Accéder à Observability Analytics
Si vous utilisez la barre de recherche pour trouver cette page, sélectionnez le résultat dont le sous-titre est Logging.
Dans le volet Requête, cliquez sur code SQL, puis copiez et collez une requête dans le volet de requête SQL.
Voici le format de la cause
FROMpour interroger la vue_AllSpans:FROM `PROJECT_ID.LOCATION._Trace.Spans._AllSpans`
La clause
FROMcontient les champs suivants :- PROJECT_ID : identifiant du projet.
- LOCATION : emplacement du bucket d'observabilité.
_Traceest le nom du bucket d'observabilité.Spansest le nom de l'ensemble de données._AllSpansest le nom de la vue.
Pour utiliser les requêtes présentées dans ce document sur la page BigQuery Studio ou l'outil de ligne de commande bq, modifiez la clause FROM et saisissez le chemin d'accès à l'ensemble de données associé.
Par exemple, pour interroger la vue _AllSpans sur l'ensemble de données associé nommé my_linked_dataset qui se trouve dans le projet myproject, le chemin d'accès est `myproject.my_linked_dataset._AllSpans`.
Cas d'utilisation courants
Cette section liste plusieurs cas d'utilisation courants qui peuvent vous aider à créer vos requêtes personnalisées.
Afficher toutes les données de trace
Pour interroger la vue _AllSpans, exécutez la requête suivante :
-- Display all data.
SELECT *
FROM `PROJECT_ID.LOCATION._Trace.Spans._AllSpans`
-- Limit to 10 entries.
LIMIT 10
Afficher les informations sur les étendues communes
Pour afficher des informations communes aux spans, comme l'heure de début et la durée, exécutez la requête suivante :
SELECT
start_time,
-- Set the value of service name based on the first non-null value in the list.
COALESCE(
JSON_VALUE(resource.attributes, '$."service.name"'),
JSON_VALUE(attributes, '$."service.name"'),
JSON_VALUE(attributes, '$."g.co/gae/app/module"')) AS service_name,
name AS span_name,
duration_nano,
status.code AS status,
trace_id,
span_id
FROM
`PROJECT_ID.LOCATION._Trace.Spans._AllSpans`
LIMIT 10
Pour en savoir plus, consultez Expressions conditionnelles.
Afficher les 50e et 99e centiles de la latence de la portée
Pour afficher les 50e et 99e centiles de la latence pour chaque service RPC, exécutez la requête suivante :
SELECT
-- Compute 50th and 99th percentiles for each service
STRING(attributes['rpc.service']) || '/' || STRING(attributes['rpc.method']) AS rpc_service_method,
APPROX_QUANTILES(duration_nano, 100)[OFFSET(50)] AS duration_nano_p50,
APPROX_QUANTILES(duration_nano, 100)[OFFSET(99)] AS duration_nano_p99
FROM
`PROJECT_ID.LOCATION._Trace.Spans._AllSpans`
WHERE
-- Matches spans whose kind field has a value of 2 (SPAN_KIND_SERVER).
kind = 2
GROUP BY rpc_service_method
Pour en savoir plus sur l'énumération, consultez la documentation OpenTelemetry : SpanKind.
Pour afficher les résultats sous forme graphique, vous pouvez créer un graphique dont la dimension est définie sur rpc_service_method. Vous pouvez ajouter deux mesures : l'une pour la moyenne de la valeur duration_nano_p50 et l'autre pour la moyenne du champ duration_nano_p99.
Filtrer les entrées de trace
Pour appliquer un filtre à votre requête, ajoutez une clause WHERE. La syntaxe que vous utilisez dans cette clause dépend du type de données du champ. Cette section fournit plusieurs exemples pour différents types de données.
Filtrer par types de données de chaîne
Le champ name est stocké en tant que String.
Pour n'analyser que les portées où
nameest spécifié, utilisez la clause suivante :-- Matches spans that have a name field. WHERE name IS NOT NULLPour n'analyser que les étendues où
namea la valeur"POST", utilisez la clause suivante :-- Matches spans whose name is POST. WHERE STRPOS(name, "POST") > 0Pour n'analyser que les portées où
namecontient la valeur"POST", utilisez l'opérateurLIKEavec des caractères génériques :-- Matches spans whose name contains POST. WHERE name LIKE "%POST%"
Filtrer par types de données entiers
Le champ kind est un nombre entier compris entre zéro et cinq :
Pour n'analyser que les portées pour lesquelles
kindest spécifié, utilisez la clause suivante :-- Matches spans that have field named kind. WHERE kind IS NOT NULLPour analyser les portées dont la valeur
kindest égale à un ou deux, utilisez la clause suivante :-- Matches spans whose kind value is 1 or 2. WHERE kind IN (1, 2)
Filtrer par types de données RECORD
Certains champs du schéma de trace ont un type de données RECORD. Ces champs peuvent stocker une ou plusieurs structures de données, ou des entrées répétées de la même structure de données.
Filtrer par état ou code d'état
Le champ status est un exemple de champ dont le type de données est RECORD. Ce champ stocke une structure de données, avec des membres libellés code et message.
Pour n'analyser les spans que lorsque le champ
status.codea une valeur de1, ajoutez la clause suivante :-- Matches spans that have a status.code field that has a value of 1. WHERE status.code = 1Le champ
status.codeest stocké sous forme d'entier.Pour analyser les étendues où le champ
statusn'est pasEMPTY, ajoutez la clause suivante :-- Matches spans that have status field. When the status field exists, it -- must contain a subfield named code. -- Don't compare status to NULL, because this field has a data type of RECORD. WHERE status.code IS NOT NULL
Filtrer par événements ou liens
Les champs events et links sont stockés avec un type de données RECORD, mais il s'agit de champs répétés.
Pour faire correspondre les étendues comportant au moins un événement, utilisez la clause suivante :
-- Matches spans that have at least one event. Don't compare events to NULL. -- The events field has data type of RECORD and contains a repeated fields. WHERE ARRAY_LENGTH(events) > 0Pour faire correspondre les portées qui comportent un événement dont le champ
namea la valeurmessage, utilisez la clause suivante :WHERE -- Exists is true when any event in the array has a name field with the -- value of message. EXISTS( SELECT 1 FROM UNNEST(events) AS ev WHERE ev.name = 'message' )
Filtrer par types de données JSON
Le champ attributes est de type JSON. Chaque attribut individuel est une paire clé/valeur.
Pour n'analyser que les portées où
attributesest spécifié, utilisez la clause suivante :-- Matches spans where at least one attribute is specified. WHERE attributes IS NOT NULLPour n'analyser que les portées dont la clé d'attribut nommée
componenta une valeur de"proxy", utilisez la clause suivante :-- Matches spans that have an attribute named component with a value of proxy. WHERE attributes IS NOT NULL AND JSON_VALUE(attributes, '$.component') = 'proxy'Vous pouvez également utiliser une instruction
LIKEavec des caractères génériques pour effectuer un test "contient" :-- Matches spans that have an attribute named component whose value contains proxy. WHERE attributes IS NOT NULL AND JSON_VALUE(attributes, '$.component') LIKE '%proxy%'
Regrouper et agréger les données de trace
Cette section explique comment regrouper et agréger des spans. Si vous ne spécifiez pas de regroupement, mais que vous spécifiez une agrégation, un seul résultat est imprimé, car SQL traite toutes les entrées qui satisfont la clause WHERE comme un seul groupe.
Chaque expression SELECT doit être incluse dans les champs de groupe ou être agrégée.
Regrouper les périodes par heure de début
Pour regrouper les données par heure de début, utilisez la fonction TIMESTAMP_TRUNC, qui tronque un code temporel selon une précision spécifiée, comme HOUR :
SELECT
-- Truncate the start time to the hour. Count the number of spans per group.
TIMESTAMP_TRUNC(start_time, HOUR) AS hour,
status.code AS code,
COUNT(*) AS count
FROM
`PROJECT_ID.LOCATION._Trace.Spans._AllSpans`
WHERE
-- Matches spans shows start time is within the previous 12 hours.
start_time > TIMESTAMP_SUB(CURRENT_TIMESTAMP(), INTERVAL 12 HOUR)
GROUP BY
-- Group by hour and status code.
hour, code
ORDER BY hour DESC
Pour en savoir plus, consultez la documentation TIMESTAMP_TRUNC et les fonctions de date et d'heure.
Nombre de spans par code d'état
Pour afficher le nombre d'étendues avec un code d'état spécifique, exécutez la requête suivante :
SELECT
-- Count the number of spans for each status code.
status.code,
COUNT(*) AS count
FROM
`PROJECT_ID.LOCATION._Trace.Spans._AllSpans`
WHERE status.code IS NOT NULL
GROUP BY status.code
Si vous remplacez status.code par kind, la requête précédente indique le nombre de portées pour chaque valeur de l'énumération kind. De même, si vous remplacez status.code par name, les résultats de la requête listent le nombre d'entrées pour chaque nom de portée.
Calculer la durée moyenne de toutes les portées
Pour afficher la durée moyenne, après avoir regroupé les données de segment par nom de segment, exécutez la requête suivante :
SELECT
-- Group by name, and then compute the average duration for each group.
name,
AVG(duration_nano) AS nanosecs,
FROM
`PROJECT_ID.LOCATION._Trace.Spans._AllSpans`
GROUP BY name
ORDER BY nanosecs DESC
Calculer la durée moyenne et les centiles par nom de service
La requête suivante calcule le nombre de spans et diverses statistiques pour chaque service :
SELECT
-- Set the service name by the first non-null value.
COALESCE(
JSON_VALUE(resource.attributes, '$."service.name"'),
JSON_VALUE(attributes, '$."service.name"'),
JSON_VALUE(attributes, '$."g.co/gae/app/module"')) AS service_name,
-- Count the number spans for each service name. Also compute statistics.
COUNT(*) AS span_count,
AVG(duration_nano) AS avg_duration_nano,
MIN(duration_nano) AS min_duration_nano,
MAX(duration_nano) AS max_duration_nano,
-- Calculate percentiles for duration
APPROX_QUANTILES(duration_nano, 100)[OFFSET(50)] AS p50_duration_nano,
APPROX_QUANTILES(duration_nano, 100)[OFFSET(95)] AS p95_duration_nano,
APPROX_QUANTILES(duration_nano, 100)[OFFSET(99)] AS p99_duration_nano,
-- Count the number of unique trace IDs. Also, collect up to 5 unique
-- span names and status codes.
COUNT(DISTINCT trace_id) AS distinct_trace_count,
ARRAY_AGG(DISTINCT name IGNORE NULLS LIMIT 5) AS sample_span_names,
ARRAY_AGG(DISTINCT status.code IGNORE NULLS LIMIT 5) AS sample_status_codes
FROM
`PROJECT_ID.LOCATION._Trace.Spans._AllSpans`
GROUP BY service_name
ORDER BY span_count DESC
Recherche dans plusieurs colonnes
Cette section décrit deux approches que vous pouvez utiliser pour rechercher des données dans plusieurs colonnes de la vue que vous interrogez :
Recherches basées sur des jetons : vous spécifiez le lieu de recherche et une requête de recherche, puis vous utilisez la fonction
SEARCH. Étant donné que la fonctionSEARCHest soumise à des règles spécifiques concernant la recherche de données, nous vous recommandons de lire la documentationSEARCH.Recherches basées sur des sous-chaînes : vous indiquez l'emplacement de la recherche, un littéral de chaîne, puis vous utilisez la fonction
CONTAINS_SUBSTR. Le système effectue un test non sensible à la casse pour déterminer si le littéral de chaîne existe dans une expression. La fonctionCONTAINS_SUBSTRrenvoieTRUElorsque le littéral de chaîne existe etFALSEdans le cas contraire. La valeur de la recherche doit être un littéral de typeSTRING, mais pas de valeur littéraleNULL.
Interroger plusieurs vues
Les instructions de requête analysent une ou plusieurs tables ou expressions, et renvoient les lignes de résultats calculés. Par exemple, vous pouvez utiliser des instructions de requête pour fusionner les résultats des instructions SELECT sur différentes tables ou ensembles de données de différentes manières, puis sélectionner les colonnes à partir des données combinées.
Pour joindre des vues, les restrictions suivantes s'appliquent :
-
Les emplacements des vues satisfont l'une des conditions suivantes :
- Toutes les vues ont le même emplacement.
- Toutes les vues se trouvent dans l'emplacement
globalouus.
-
Lorsque les ressources de stockage utilisent des clés de chiffrement gérées par le client (CMEK), l'une des conditions suivantes doit être remplie :
- Les ressources de stockage qui utilisent CMEK utilisent la même clé Cloud KMS.
- Les ressources de stockage qui utilisent CMEK ont un ancêtre commun, et cet ancêtre spécifie une clé Cloud KMS par défaut qui se trouve au même emplacement que les ressources de stockage.
Lorsqu'une ou plusieurs ressources de stockage utilisent le CMEK, le système chiffre les données temporaires générées par la jointure avec la clé Cloud KMS commune ou la clé Cloud KMS par défaut de l'ancêtre.
Par exemple, supposons que vous ayez deux vues qui se trouvent au même emplacement. Vous pouvez ensuite joindre ces vues si l'une des conditions suivantes est remplie :
- Les ressources de stockage n'utilisent pas CMEK.
- Une ressource de stockage utilise CMEK, mais pas l'autre.
- Les deux ressources de stockage utilisent le chiffrement CMEK et la même clé Cloud KMS.
Les deux ressources de stockage utilisent CMEK, mais avec des clés différentes. Toutefois, les ressources partagent un ancêtre qui spécifie une clé Cloud KMS par défaut située au même emplacement que les ressources de stockage.
Par exemple, supposons que la hiérarchie des ressources pour un bucket de journaux et un bucket d'observabilité inclue la même organisation. Vous pouvez joindre des vues sur ces buckets lorsque, pour cette organisation, vous avez configuré les paramètres de ressources par défaut pour Cloud Logging et pour les buckets d'observabilité avec la même clé Cloud KMS par défaut pour l'emplacement de stockage.
Joindre les données de trace et de journal à l'aide de l'ID de trace
La requête suivante joint les données de journaux et de trace à l'aide des ID de span et de trace :
SELECT
T.trace_id,
T.span_id,
T.name,
T.start_time,
T.duration_nano,
L.log_name,
L.severity,
L.json_payload
FROM
`PROJECT_ID.LOCATION._Trace.Spans._AllSpans` AS T
JOIN
`PROJECT_ID.LOCATION._Default._AllLogs` AS L
ON
-- Join log and trace data by both the span ID and trace ID.
-- Don't join only on span ID, this field isn't globally unique.
T.span_id = L.span_id
-- A regular expression is required because the storage format of the trace ID
-- differs between a log view and a trace view.
AND T.trace_id = REGEXP_EXTRACT(L.trace, r'/([^/]+)$')
WHERE T.duration_nano > 1000000
LIMIT 10
La réponse à la requête liste l'ID de trace et d'étendue, ce qui vous permet de les interroger individuellement pour obtenir plus d'informations. La liste des résultats indique également la gravité de l'entrée de journal et la charge utile JSON.
Étapes suivantes
- Enregistrer et partager une requête SQL
- Représenter les résultats d'une requête SQL sous forme de graphique
- Interrogez un ensemble de données associé dans BigQuery.
Pour obtenir la documentation de référence SQL ou d'autres exemples, consultez les documents suivants :
- Fonctions, opérateurs et expressions conditionnelles
- Fonctions de recherche.
- Syntaxe des requêtes
- Exemples de requêtes SQL pour Cloud Logging