Identifier les transactions susceptibles d'entraîner des latences élevées

Cette page explique comment utiliser les insights sur les verrouillages et Les insights sur les transactions pour identifier les transactions qui génèrent des les latences.

Présentation

Pour garantir la cohérence de plusieurs transactions simultanées, Spanner utilise des verrous pour contrôler l'accès aux données. Un conflit de verrouillage se produit lorsque de nombreuses transactions nécessitent un accès fréquent à la même serrure, ce qui entraîne des latences élevées. Sans une interface visuelle, il peut être fastidieux d'identifier les transactions problématiques ce qui entraîne un grand nombre de problèmes de conflit de verrous.

Les opérations Spanner acquièrent des verrous lorsqu'elles font partie read-write. Les transactions en lecture seule n'acquièrent pas de verrous.

Spanner vous aide à identifier les transactions qui conduisent en vous guidant tout au long des étapes suivantes:

  1. Vérifiez les pics de latence à l'aide de Spanner Monitoring.
  2. Recherchez les problèmes de conflit de verrouillage à l'aide des insights sur les verrouillages.
  3. Identifiez les transactions problématiques à l'aide des insights sur les transactions.

Tarifs

Les insights sur les verrous et les insights sur les transactions n'entraînent aucuns frais supplémentaires.

Configurations régionales

Les insights sur les verrous et les insights sur les transactions sont disponibles dans à la fois régionaux et multirégionaux.

Conservation des données

Conservation maximale des données affichées sur le Les insights sur les verrouillages et les tableaux de bord "Insights sur les transactions" couvrent 30 jours. Pour les graphiques, les données sont extraites de SPANNER_SYS.* tables, qui ont une durée de conservation maximale de 30 jours.

Pour en savoir plus sur ces tables et la conservation des données, consultez Statistiques sur le verrouillage et Statistiques sur les transactions :

Rôles requis

Vous avez besoin de différents rôles et autorisations IAM selon que vous êtes un utilisateur IAM ou un utilisateur du contrôle des accès ultraprécis.

Utilisateur IAM (Identity and Access Management)

Afin d'obtenir les autorisations nécessaires pour afficher la page "Insights sur les verrous et transactions", demandez à votre administrateur de vous accorder le les rôles IAM suivants sur l'instance:

Vous devez disposer des autorisations suivantes du rôle Lecteur de bases de données Cloud Spanner (roles/spanner.databaseReader) pour afficher la page "Insights sur les verrous et transactions" :

  • spanner.databases.beginReadOnlyTransaction
  • spanner.databases.select
  • spanner.sessions.create

Utilisateur pour le contrôle ultraprécis des accès

Si vous êtes un utilisateur du contrôle des accès ultraprécis, assurez-vous de respecter les points suivants:

  • Vous disposez du lecteur Cloud Spanner(roles/spanner.viewer).
  • Ils ne disposent que des droits de contrôle des accès ultraprécis et disposent du spanner_sys_reader. rôle système ou de l'un de ses rôles de membre.
  • Sélectionnez le rôle spanner_sys_reader ou un rôle de membre comme rôle système actuel sur la page de présentation de la base de données.

Pour en savoir plus, consultez les pages À propos du contrôle ultraprécis des accès et Rôles système de contrôle des accès ultraprécis

Rechercher un pic de latence à l'aide de Spanner Monitoring

Vous pouvez utiliser Cloud Monitoring pour définir des alertes pour les métriques qui dépassent les valeurs spécifiées pour toutes les demandes.

Si vous recevez une alerte indiquant un pic de latence pour une vous pouvez le confirmer à l'aide de la clé Spanner Tableau de bord Monitoring, qui affiche des graphiques pour différentes métriques importantes. Le graphique Latence vous aide à visualiser les métriques les latences aux 50e et 99e centiles.

Pour confirmer un pic de latence d'écriture au 99e centile, procédez comme suit:

  1. Dans la console Google Cloud, accédez à la page Instances Spanner.

    Accéder à la page Instances Spanner

  2. Cliquez sur le nom de l'instance.

    La console Google Cloud affiche un aperçu de l'instance.

  3. Cliquez sur Surveillance dans le menu de navigation.

    La console Google Cloud affiche des graphiques de données pour Compute Engine.

  4. Dans le graphique Latence, définissez Fonction sur Write et Centile sur 99th.

  5. Consultez le graphique actualisé pour voir s'il présente des pics.

Graphique montrant les latences d'écriture au 99e centile

Si vous constatez que l'utilisation du processeur n'augmente pas et que le nombre d'erreurs augmente d'opérations par seconde, il est probable que les pics de latence soient dus au verrouillage les conflits.

Rechercher des problèmes de conflit de verrouillage à l'aide des insights sur les verrouillages

Le tableau de bord des insights sur les verrouillages vous aide à consulter le temps d'attente de verrouillage ou d'une base de données sélectionnée. Cela peut vous aider à vérifier si des latences élevées sont en raison de conflits de verrouillage.

Vérifiez si le temps d'attente de verrouillage est élevé

Pour vérifier si le temps d'attente de verrouillage est élevé, procédez comme suit:

  1. Cliquez sur Verrouiller les insights dans le menu de navigation.

    La console Google Cloud affiche le délai d'attente total pour le verrouillage (Total Lock Wait). qui affiche le temps d'attente lié au verrouillage pour chaque base de données de l'instance.

    Par défaut, les données affichées concernent 1 hour, le sélecteur de temps au niveau l'angle supérieur droit du tableau de bord des insights sur les verrouillages s'affiche. Pour consulter les données pour une plage plus large, sélectionnez une autre option, par exemple 1 day.

    Pour en savoir plus, consultez la page Travailler avec des graphiques.

  2. Dans le sélecteur Bases de données en haut, sélectionnez la base de données qui affiche le temps d'attente de verrouillage le plus élevé.

    Le graphique Délai total de verrouillage s'actualise et n'affiche que les données de la base de données sélectionnée.

    En outre, un autre graphique, Délai de verrouillage par plage de lignes, affiche les graphiques pour temps d'attente de verrouillage par plage de lignes.

  3. Cliquez sur le graphique et faites-le glisser horizontalement pour augmenter l'heure à laquelle une latence se produit. est visible.

Le tableau de bord des insights sur les verrouillages

Analyser les données d'attente de verrouillage

Le tableau Lock Insights (Insights sur les verrouillages) affiche les colonnes suivantes des SPANNER_SYS.LOCK_STATS tables système:

  • Row range start key: clé de ligne dans laquelle le conflit de verrouillage s'est produit. Quand ? le conflit implique une plage de lignes, la valeur représente la clé de début de la plage. Le signe plus (+) représente une plage.
  • Délai d'attente pour le verrouillage: temps total d'attente lié au verrouillage représenté visuellement dans une barre horizontale. Par défaut, le tableau utilise cette colonne pour les tris et affiche la clé de début de plage de lignes avec le temps d'attente de verrouillage le plus élevé en haut.
  • Délai d'attente (en secondes): temps d'attente cumulé pour les conflits de verrouillage enregistré. pour toutes les colonnes de la plage de clés de ligne, en secondes.
  • Attente du verrouillage (%): temps d'attente lié aux conflits de verrouillage colonnes de la plage de clés de ligne sous la forme d'un pourcentage du temps d'attente total du verrouillage pour toutes des plages de clés de ligne dans la base de données.

Pour corréler les données du graphique Attente de verrouillage par plage de lignes avec les données de dans le tableau, sélectionnez une ligne. La ligne associée apparaît en surbrillance. À l'inverse, sélectionnez la case à cocher d’une ligne du tableau pour afficher la ligne associée sur le graphique.

Tableau des insights sur les verrouillages

Pour filtrer les données du tableau, procédez comme suit:

  1. Cliquez dans la zone de texte à côté de Filtrer.

  2. Sélectionnez une propriété, un opérateur et une valeur.

Le tableau affiche les données correspondant au filtre.

Afficher des exemples de demandes de verrouillage

Le panneau Exemples de demandes de verrouillage affiche des détails sur l'exemple de verrouillage des requêtes de transactions concurrentes.

Pour afficher un exemple d'informations de demande de verrouillage pour une clé de début de plage de lignes, cliquez sur le lien associé dans le tableau.

Le tableau présente les colonnes d'informations suivantes:

  • Sample column name (Exemple de nom de colonne) : colonne qui a rencontré le verrou un conflit sur la plage de clés de ligne.
  • Mode verrouillé: mode verrouillé demandé.
  • Afficher les transactions: lien vers la page Insights sur les transactions, affiche les transactions susceptibles d'être en concurrence pour des verrous.

Page d'informations sur les insights sur les verrouillages

Identifier les transactions concurrentes à l'aide des insights sur les transactions

Le tableau de bord "Informations sur les transactions" vous permet de visualiser la latence des transactions sur une instance ou une base de données sélectionnée. Il peut vous aider à identifier les transactions ce qui peut entraîner des latences élevées en raison de conflits de verrous.

Afficher la latence des transactions

Pour afficher la latence des transactions, procédez comme suit:

  1. Cliquez sur Insights sur les transactions dans le menu de navigation de gauche.

  2. Dans le sélecteur Bases de données en haut, sélectionnez la base de données qui affiche le temps d'attente de verrouillage le plus élevé.

    Dans le tableau de bord des insights sur les verrouillages, vous pouvez également cliquer sur Afficher transactions pour filtrer les transactions de lecture ou d'écriture exemple de colonne.

    Par défaut, les données affichées concernent 1 hour, le sélecteur de temps au niveau figurant dans l'angle supérieur droit du tableau de bord "Informations sur les transactions".

Le tableau de bord affiche les graphiques suivants:

  • Le graphique Latence moyenne (toutes les transactions) affiche la latence pour toutes les données des transactions dans l'instance.

  • Le graphique Latence moyenne (par transaction) affiche la latence pour chaque pour la base de données sélectionnée.

Tableau de bord "Informations sur les transactions"

Analyser les données de transaction

Vous pouvez consulter et analyser les données relatives à chaque transaction dans le tableau situé sous le graphiques. Le tableau affiche les données des métriques de SPANNER_SYS.TXN_STATS. tables système dans les colonnes suivantes:

  • Empreinte: le hachage de la balise de transaction, le cas échéant. Sinon, le hachage est calculé en fonction des opérations impliquées dans la transaction. La valeur est Un lien qui mène à la page Détails de la transaction
  • Balise de transaction: balise de transaction facultative pour la transaction. Données statistiques pour plusieurs transactions portant la même balise est regroupée sur une ligne unique dont le libellé TRANSACTION_TAG correspond à .
  • Tables concernées: tables affectées par la transaction.
  • Table.column Read: colonnes dans lesquelles la transaction lit les données.
  • Table.column Écrire: colonnes dans lesquelles la transaction a écrit.
  • Latence moyenne (secondes): nombre moyen de secondes nécessaires pour effectuer la transaction. Par défaut, le tableau est trié en fonction de cette colonne dans l'ordre décroissant.

Pour corréler les données du graphique Latence moyenne (par transaction) avec le données du tableau, sélectionnez une ligne du graphique. La ligne correspondante dans le tableau apparaît en surbrillance.

Pour filtrer les données du tableau, procédez comme suit:

  1. Cliquez à côté de Filtrer.

  2. Sélectionnez une propriété, un opérateur et une valeur.

Le tableau affiche les données correspondant au filtre.

Tableau des insights sur les transactions

Afficher des informations détaillées sur une transaction

Pour afficher des informations détaillées sur une transaction, comme celle indiquant le la latence la plus élevée, cliquez sur le lien Empreinte digitale sur la ligne correspondante du tableau.

La page Détails de la transaction s'affiche. En plus du tableau des détails en haut, il affiche les informations suivantes:

  • Barre affichant des valeurs numériques pour chacune de ces métriques:

    • Nombre moyen d'octets: nombre moyen d'octets écrits par la transaction.
    • Latence moyenne: nombre moyen de secondes issues de la première opération de la transaction à valider ou à abandonner.
    • Latence moyenne du commit: nombre moyen de secondes nécessaires pour effectuer l'opération de commit.
    • Nombre total de tentatives: nombre total de tentatives de transaction.
    • Nombre total d'annulations: nombre total de tentatives de transaction ayant été annulées, y compris celles qui sont annulées avant l'appel de la méthode commit.
  • Graphiques illustrant ces valeurs

    De plus, le graphique Nombre moyen de participants indique le nombre moyen de participants dans chaque tentative de commit.

Page d'informations des insights sur les transactions

Vérifiez si la forme de la transaction peut être optimisée pour réduire les latences. Pensez à appliquer les pratiques recommandées pour réduire les conflits de verrouillage.

Étape suivante