Aktive Abfragen überwachen

Auf dieser Seite wird beschrieben, wie Sie die in Ihrer Datenbank aktiven Abfragen überwachen und Fehler beheben. Mit dem Monitoring dieser Abfragen können Sie Ursachen für Systemlatenz und hohe CPU-Auslastung erkennen.

Im Dashboard „Query Insights“ können Sie eine Zusammenfassung der aktiven Transaktionen und eine Liste der Transaktionen mit zugehörigen Abfragen und Statistiken aufrufen. Die Transaktionen werden nach der Startzeit der Transaktion angezeigt. Wenn sehr viele Abfragen ausgeführt werden, sind die Ergebnisse möglicherweise auf eine Teilmenge der Gesamtabfragen beschränkt.

Hinweis

Zum Überwachen aktiver Abfragen können Sie entweder die Cloud SQL Enterprise-Version oder die Cloud SQL Enterprise Plus-Version verwenden.

Wenn Sie eine Sitzung oder eine lang andauernde Transaktion in aktiven Abfragen beenden möchten, müssen Sie die Cloud SQL Enterprise Plus-Version für Ihre Cloud SQL-Instanz verwenden.

Weitere Informationen zu den Cloud SQL-Versionen finden Sie unter Einführung in die Cloud SQL-Versionen.

Erforderliche Rollen und Berechtigungen

Bitten Sie Ihren Administrator, Ihnen die folgenden IAM-Rollen für das Projekt zuzuweisen, in dem sich die Cloud SQL-Instanz befindet, damit Sie die Berechtigungen erhalten, die Sie zum Aufrufen aktiver Abfragen benötigen:

Weitere Informationen zum Zuweisen von Rollen finden Sie unter Zugriff auf Projekte, Ordner und Organisationen verwalten.

Diese vordefinierten Rollen enthalten die Berechtigungen, die zum Aufrufen aktiver Abfragen erforderlich sind. Maximieren Sie den Abschnitt Erforderliche Berechtigungen , um die notwendigen Berechtigungen anzuzeigen, die erforderlich sind:

Erforderliche Berechtigungen

Zum Aufrufen aktiver Abfragen sind die folgenden Berechtigungen erforderlich:

  • Zusammenfassung der Datenbankaktivität und lang andauernde Transaktionen ansehen:
    • databaseinsights.activeQueries.fetch
    • databaseinsights.activitySummary.fetch

Sie können diese Berechtigungen auch mit benutzerdefinierten Rollen oder anderen vordefinierten Rollen erhalten.

Aktive Abfragen aktivieren

Wenn Sie Query Insights aktivieren, werden aktive Abfragen automatisch aktiviert. Wenn Sie eine Sitzung oder eine lang andauernde Transaktion in aktiven Abfragen beenden möchten, müssen Sie Query Insights für die Cloud SQL Enterprise Plus-Version verwenden.

Aktive Abfragen deaktivieren

Sie können aktive Abfragen nicht deaktivieren, ohne Query Insights zu deaktivieren. Informationen zum Deaktivieren von aktiven Abfragen und Query Insights finden Sie unter Query Insights deaktivieren.

Aktive Abfragen ansehen

So rufen Sie Ihre aktiven Abfragen auf:

  1. Öffnen Sie in der Google Cloud Console die Cloud SQL-Instanzen Seite.

    Cloud SQL-Instanzen aufrufen

  2. Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.

  3. Führen Sie einen der folgenden Schritte aus, um das Dashboard Query Insights aufzurufen:

    • Wählen Sie den Tab Query Insights aus.
    • Zu „Query Insights“ für ausführliche Informationen über Abfragen und zur Leistung Das Dashboard Query Insights wird geöffnet. Oben werden Details zur Instanz angezeigt.
  4. Klicken Sie auf den Tab Aktive Abfragen.

    Von hier aus können Sie die Abfrageinformationen ändern, die in der Tabelle Am längsten laufende Transaktionen angezeigt werden:

    • Datenbanken: Filtert die Abfragelast für eine bestimmte Datenbank oder für alle Datenbanken.
    • Nutzer: Filtert die Abfragelast aus einem bestimmten Nutzerkonto.

Normalisierte aktive Abfragen ansehen

Sie können eine Liste der lang andauernden Transaktionen mit normalisierten aktiven Abfragen im Dashboard Query Insights aufrufen. Eine normalisierte aktive Abfrage entfernt sensible Daten und gibt einen Digest zurück. Der Digest ist für verschiedene Werte identisch, die im folgenden Beispiel verwendet werden:

  • Reguläre Abfragen

    • select * from test_table where id=1;
    • select * from test_table_where id=2;
  • Digest- oder normalisierte Abfrage

    • select * from test_table where id=?;

Eine Abfrage, die in verschiedenen Sitzungen ausgeführt wird, wird im Dashboard als unterschiedliche Einträge angezeigt.

Am längsten laufende Transaktionen ansehen

Die Tabelle Am längsten laufende Transaktionen im Dashboard Query Insights enthält die folgenden Spalten:

Spaltenname Beschreibung
Sitzungs-ID Eindeutige Kennung der Sitzung.
Abfrage SQL-Abfragetext.
Sitzungsstatus Der Status der Sitzung.
Abfragedauer Wie lange die Abfrage ausgeführt wurde.
ID der blockierenden Sitzung Die ID der Sitzung, die die Sitzung blockiert.
Warteereignistyp Der Typ des Warteereignisses, wenn die Anfrage für die Ausführung der Abfrage blockiert ist.
Warteressource Die Ressource, auf die die Anfrage derzeit wartet, wenn die Anfrage für die Ausführung der Abfrage blockiert ist.
Transaktionswartezeit Die Dauer der aktuellen Wartezeit, wenn die Sitzung blockiert ist.
Logische Lesevorgänge Die Anzahl der logischen Lesevorgänge, die von der Anfrage ausgeführt wurden.
Lesevorgänge Die Anzahl der Lesevorgänge, die von der Anfrage ausgeführt wurden.
Schreibvorgänge Die Anzahl der Schreibvorgänge, die von der Anfrage ausgeführt wurden.
Datenbank Datenbank, in der die Sitzung ausgeführt wird.
Nutzer Name des Nutzers, der mit der Datenbank verbunden ist.
Clientadresse Die bestimmte IP-Adresse des Clients, der eine Abfrage gesendet hat.
CPU-Zeit (ms) Die CPU-Zeit in Millisekunden, die von der Anfrage verwendet wird.
Name der Anwendung Name der Anwendung, die die Sitzung initiiert hat.
Geänderte Transaktionszeilen Anzahl der Zeilen, die von dieser Abfrage an den Client zurückgegeben wurden.
% abgeschlossen Prozent der erledigten Arbeit, wenn die Abfrage den Fortschritt meldet.
Zugewiesener Abfragearbeitsspeicher Die Anzahl der Seiten, die für die Ausführung der Anfrage zugewiesen wurden.
Aktion Enthält einen Link zum Beenden einer Sitzung.

Die Anzeige wird alle 60 Sekunden automatisch aktualisiert.

Im vertikalen Menü Optionen für die Inhaltsanzeige... können Sie die Spalten filtern, die angezeigt werden sollen.

Sitzung beenden

Wenn Sie eine Sitzung oder eine lang andauernde Transaktion beenden möchten, müssen Sie die Cloud SQL Enterprise Plus-Version verwenden und Query Insights für die Cloud SQL Enterprise Plus-Version aktivieren.

Das Beenden von Vorgängen mit langer Ausführungszeit kann länger dauern.

So beenden Sie eine Abfrage oder Transaktion:

  1. Wählen Sie in der Tabelle Am längsten laufende Transaktion eine Abfrage aus.
  2. Klicken Sie in der Spalte Aktion auf Sitzung beenden.
  3. Klicken Sie im Fenster Sitzung beenden auf Bestätigen.

Blockierte aktive Abfragen

Wenn eine bestimmte aktive Abfrage blockiert ist oder viel länger als erwartet ausgeführt wird, kann sie andere abhängige Abfragen blockieren.

In Cloud SQL haben Sie die Möglichkeit, bestimmte lang andauernde oder blockierte aktive Abfragen zu beenden.

Analyse blockierter aktiver Abfragen aktivieren

Standardmäßig wird in der Console nicht angezeigt,welche aktiven Abfragen blockiert sind. Google Cloud

Für die Analyse blockierter aktiver Abfragen gelten die folgenden Anforderungen:

So aktivieren Sie die Analyse blockierter aktiver Abfragen:

Console

  1. Öffnen Sie in der Google Cloud Console die Cloud SQL-Instanzen Seite.

    Cloud SQL-Instanzen aufrufen

  2. Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.
  3. Klicken Sie auf Bearbeiten.
  4. Maximieren Sie den Abschnitt Query Insights.
  5. Wählen Sie sowohl Query Insights aktivieren als auch Enterprise Plus-Funktionen aktivieren aus. Beide Einstellungen sind erforderlich.
  6. Wählen Sie Analyse blockierter Abfragen aus.
  7. Klicken Sie auf Speichern.

Blockierte aktive Abfrage identifizieren und beenden

Die folgenden Schritte zeigen, wie Sie eine bestimmte aktive Abfrage identifizieren und beenden, die möglicherweise andere Abfragen blockiert.

Console

  1. Öffnen Sie in der Google Cloud Console die Cloud SQL-Instanzen Seite.

    Cloud SQL-Instanzen aufrufen

  2. Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.
  3. Klicken Sie im SQL-Navigationsmenü auf Query Insights.
  4. Klicken Sie auf den Tab Aktive Abfragen.

    Wenn Sie noch keine aktiven Abfragen ausführen, rufen Sie Cloud SQL Studio auf und führen Sie die Abfragen aus, die Sie untersuchen möchten.

  5. Wechseln Sie zum Abschnitt Am längsten laufende Transaktionen. Unter jeder Kategorie sehen Sie bis zu 50 der am längsten laufenden aktiven Abfragen.

    Für jeden angezeigten Eintrag werden Details zur aktiven Abfrage angezeigt, darunter:

    • Sitzungs-ID: Die Sitzungs-ID der Abfrage. Klicken Sie auf Maximieren , um den Eintrag aufzurufen. Sie sehen eines von zwei Symbolen:
      • Sanduhrsymbol: Dieses Symbol zeigt an, dass die Abfrage darauf wartet, dass eine andere Abfrage abgeschlossen wird. Wenn neben dem Symbol eine Zahl steht, gibt sie an, wie viele abhängige Abfragen darauf warten, dass diese Abfrage abgeschlossen wird.
      • Symbol für Blockierung: Dieses Symbol zeigt an, dass die Abfrage nicht abgeschlossen werden kann und möglicherweise andere Abfragen blockiert.
    • Abfrage: SQL-Abfragetext.
    • Sitzungsstatus: Der Status der Sitzung.
    • Abfragedauer (Sekunden): Wie lange die Abfrage ausgeführt wurde.
    • CPU-Zeit(ms): Die CPU-Zeit in Millisekunden, die von der Anfrage verwendet wird.
    • Warteereignistyp: Der Typ des Warteereignisses, wenn die Anfrage für die Ausführung der Abfrage blockiert ist.
    • Warteressource: Die Ressource, auf die die Anfrage derzeit wartet, wenn die Anfrage für die Ausführung der Abfrage blockiert ist.
    • Transaktionswartezeit (Sekunden): Die Dauer der aktuellen Wartezeit, wenn die Sitzung blockiert ist.
    • Aktion: Mögliche Maßnahmen, z. B. Sitzung beenden.

    Klicken Sie, um die Sitzungs-ID zu maximieren, die Sie untersuchen möchten. Sie können untergeordnete Sitzungen im Untersuchungsbaum bis zu drei Ebenen tief maximieren.

  6. Identifizieren Sie die blockierte Abfrage und klicken Sie dann auf Sitzung beenden. Nachdem Sie die Sitzung beendet haben, können Sie zu Cloud SQL Studio wechseln, um Ihre aktiven Abfragen noch einmal auszuführen.

Details zu blockierenden Sitzungen im Leerlauf ansehen

Auf dem Tab Aktive Abfragen werden Sitzungen angezeigt, in denen derzeit eine Anfrage verarbeitet wird. Sitzungen im Status SLEEPING sind in dieser Ansicht ausgeschlossen.

Verwenden Sie das folgende Skript, um den letzten Befehl aufzurufen, der für eine Sitzung im Leerlauf ausgeführt wurde:

SELECT c.session_id, st.text,s.login_name, s.open_transaction_count, s.host_name, s.program_name
FROM sys.dm_exec_connections AS c JOIN sys.dm_exec_sessions AS S ON c.session_id=s.session_id
CROSS APPLY sys.dm_exec_sql_text(c.most_recent_sql_handle) AS st
WHERE s.session_id=BLOCKING_SESSION_ID

Ersetzen Sie BLOCKING_SESSION_ID durch die ID der Sitzung, die die Blockierung verursacht.

Weitere Informationen zur Fehlerbehebung und zum Beheben von Blockierungen finden Sie in den folgenden Ressourcen:

Nächste Schritte