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 Query Insights-Dashboard 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.
Hinweise
Sie können aktive Abfragen entweder mit Cloud SQL Enterprise oder Cloud SQL Enterprise Plus überwachen.
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, um die Berechtigungen zu erhalten, die Sie zum Aufrufen aktiver Abfragen benötigen:
-
Zusammenfassung der Instanzaktivität ansehen:
Cloud SQL-Betrachter (
roles/cloudsql.viewer
) -
Zusammenfassung der Datenbankaktivitäten und lang andauernde Transaktionen ansehen:
Database Insights Viewer (
roles/databaseinsights.viewer
) -
Eine Sitzung oder einen lang andauernden Vorgang beenden:
-
Cloud SQL Editor (
roles/cloudsql.editor
) -
Administrator für Database Insights Operations (
roles/databaseinsights.operationsAdmin
)
-
Cloud SQL Editor (
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. Erweitern Sie den Abschnitt Erforderliche Berechtigungen, um die erforderlichen Berechtigungen anzuzeigen:
Erforderliche Berechtigungen
Die folgenden Berechtigungen sind erforderlich, um aktive Abfragen aufzurufen:
-
Zusammenfassung der Datenbankaktivitäten und lange laufende 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
So aktivieren Sie aktive Abfragen für eine Cloud SQL Enterprise-Instanz:
-
Wechseln Sie in der Google Cloud Console zur Seite Cloud SQL-Instanzen.
- Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.
- Klicken Sie in der Kachel Konfiguration auf Konfiguration bearbeiten.
- Maximieren Sie im Bereich Instanz anpassen den Eintrag Query Insights.
- Achten Sie darauf, dass Query Insights aktivieren aktiviert ist.
- Wählen Sie Analyse aktiver Abfragen aus.
- Klicken Sie auf Speichern.
So aktivieren Sie aktive Abfragen für eine Cloud SQL Enterprise Plus-Instanz:
-
Wechseln Sie in der Google Cloud Console zur Seite Cloud SQL-Instanzen.
- Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.
- Klicken Sie in der Kachel Konfiguration auf Konfiguration bearbeiten.
- Maximieren Sie im Bereich Instanz anpassen den Eintrag Query Insights.
- Achten Sie darauf, dass Query Insights aktivieren aktiviert ist.
- Wählen Sie Enterprise Plus-Funktionen aktivieren aus.
- Wählen Sie Analyse aktiver Abfragen aus.
- Klicken Sie auf Speichern.
Wenn Sie eine Sitzung oder eine lang andauernde Transaktion in aktiven Abfragen beenden möchten, müssen Sie Query Insights für Cloud SQL Enterprise Plus verwenden.
Aktive Abfragen deaktivieren
So deaktivieren Sie aktive Abfragen für eine Cloud SQL Enterprise- oder Cloud SQL Enterprise Plus-Instanz:
-
Wechseln Sie in der Google Cloud Console zur Seite Cloud SQL-Instanzen.
- Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.
- Klicken Sie in der Kachel Konfiguration auf Konfiguration bearbeiten.
- Maximieren Sie im Bereich Instanz anpassen den Eintrag Query Insights.
- Entfernen Sie das Häkchen aus dem Kästchen Analyse aktiver Abfragen.
- Klicken Sie auf Speichern.
Aktive Abfragen ansehen
So rufen Sie Ihre aktiven Abfragen auf:
Wechseln Sie in der Google Cloud Console zur Seite Cloud SQL-Instanzen.
Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.
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.
Klicken Sie auf den Tab Aktive Anfragen.
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.
Zusammenfassung aller aktiven Abfragen: Hier finden Sie einen Überblick über alle aktiven Abfragen, wobei die Gesamtzahl der Verbindungen basierend auf den folgenden Parametern angezeigt wird:
- Verteilung der aktiven Verbindungen, die nach Verbindungsstatus kategorisiert sind.
- Verteilung der aktiven Transaktionen nach dem Transaktionsstatus.
- Verteilung der Abfragedauer.
- Am längsten laufende Transaktionen: Bietet einen Überblick über die 50 am häufigsten ausgeführten Abfragen (im Status aktiv und inaktiv im Transaktionsstatus) basierend auf absteigender Ausführungszeit. Sie können aktive Abfragen in der Tabelle filtern und sortieren.
Normalisierte aktive Abfragen ansehen
Sie können eine Liste der lang andauernden Transaktionen mit normalisierten aktiven Abfragen im Dashboard Query Insights aufrufen. Bei einer normalisierten aktiven Abfrage werden sensible Daten entfernt und ein Digest zurückgegeben. 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 Abfragestatistiken enthält die folgenden Spalten:
Spaltenname | Beschreibung |
---|---|
Prozess-ID | Eindeutige Kennung der Verbindung oder Thread-ID. |
Abfrage | SQL-Abfragetext. |
Status | Status der Verbindungen. |
Sitzungsdauer | Dauer der letzten ausgeführten Sitzung. |
Transaktionsdauer | Dauer der ausgeführten aktiven Transaktion. |
Abfragedauer | Dauer der letzten in dieser Transaktion ausgeführten Abfrage. |
Warteereignistyp | Warteereignistyp des auftretenden Warteereignisses. |
Warteereignis | Anstehendes Warteereignis. |
Datenbank | Datenbankname, auf dem diese Verbindung ausgeführt wird. |
Name der Anwendung | Name der Anwendung, auf der diese Verbindung ausgeführt wird. |
Nutzername | Name des Nutzers, der mit der Datenbank verbunden ist. |
Clientadresse | Bestimmte IP-Adresse des Clients, der eine Abfrage gesendet hat. |
Aktion | Enthält einen Link zum Beenden einer Transaktion. |
Die Anzeige wird alle 60 Sekunden automatisch aktualisiert.
Vorgang beenden
Wenn Sie einen Prozess oder eine lang andauernde Transaktion in aktiven Abfragen beenden möchten, müssen Sie die Cloud SQL Enterprise Plus-Version verwenden und sowohl Analyse aktiver Abfragen als auch Abfragestatistiken für die Cloud SQL Enterprise Plus-Version aktivieren.
Lang andauernde Vorgänge können länger dauern, bis sie beendet werden.
So beenden Sie eine Abfrage oder Transaktion:
- Wählen Sie in der Tabelle Am längsten laufende Transaktion eine Abfrage aus.
- Klicken Sie in der Spalte Aktion auf Verbindung beenden.
- Klicken Sie im Fenster Verbindung beenden auf Bestätigen.
Wenn das System die Abfrage oder Transaktion erfolgreich beendet hat, wird eine Erfolgsmeldung angezeigt. Das System führt bei Bedarf auch ein Rollback durch.
Blockierte aktive Abfragen
Wenn eine bestimmte aktive Abfrage blockiert wird oder viel länger als erwartet ausgeführt wird, kann sie andere abhängige Abfragen blockieren.
Mit Cloud SQL haben Sie die Möglichkeit, bestimmte aktive Abfragen mit langer Ausführungszeit oder blockierte aktive Abfragen zu beenden.
Analyse blockierter aktiver Abfragen aktivieren
Standardmäßig wird in der Google Cloud Console nicht angezeigt,welche aktiven Abfragen blockiert werden. Damit Sie blockierte aktive Abfragen analysieren können, müssen sowohl die Cloud SQL Enterprise Plus-Edition als auch aktive Abfragen für die Instanz aktiviert sein.
So aktivieren Sie die Analyse blockierter aktiver Abfragen:
Konsole
-
Wechseln Sie in der Google Cloud Console zur Seite Cloud SQL-Instanzen.
- Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.
- Klicken Sie auf Bearbeiten.
- Maximieren Sie Query Insights.
- Wählen Sie sowohl Enterprise Plus-Funktionen aktivieren als auch Analyse aktiver Abfragen aus. Beide Einstellungen sind erforderlich.
- Wählen Sie Analyse blockierter Abfragen aus.
- Klicken Sie auf Speichern.
Blockierte aktive Abfrage identifizieren und beenden
In den folgenden Schritten wird beschrieben, wie Sie eine bestimmte aktive Abfrage identifizieren und beenden, die möglicherweise andere Abfragen blockiert.
Konsole
-
Wechseln Sie in der Google Cloud Console zur Seite Cloud SQL-Instanzen.
- Klicken Sie auf den Instanznamen, um die Übersichtsseite einer Instanz zu öffnen.
- Klicken Sie im SQL-Navigationsmenü auf Query Insights.
- Klicken Sie auf den Tab Aktive Anfragen.
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.
- Rufen Sie den Bereich Am längsten laufende Transaktionen auf. Sie können bis zu 50 der aktiven Abfragen mit der längsten Ausführungszeit sehen.
Jeder angezeigte Eintrag enthält die folgenden Informationen:
- Prozess-ID: Die Prozess-ID der Abfrage. Klicken Sie auf
- Stundenglassymbol: Dieses Symbol weist darauf hin, dass der Prozess darauf wartet, dass eine andere Abfrage abgeschlossen wird. Wenn neben dem Symbol eine Zahl angezeigt wird, gibt diese an, wie viele abhängige Abfragen darauf warten, dass dieser Prozess abgeschlossen wird.
- Symbol für Blockierung: Dieses Symbol weist darauf hin, dass der Prozess nicht abgeschlossen werden kann und möglicherweise andere Anfragen blockiert.
Maximieren, um den Eintrag aufzurufen. Sie sehen eines von zwei Symbolen:
- Abfragetyp: Der Typ der ausgeführten Abfrage, z. B.
SELECT
oderUPDATE
. - Status: Der Status der aktiven Anfrage, z. B.
ACTIVE
. - Sitzungsdauer (Sekunden): Die Dauer der aktuellen Sitzung (in Sekunden).
- Transaktionsdauer (Sekunden): Die Dauer der aktuell aktiven Transaktion (in Sekunden).
- Abfragedauer (Sekunden): Die Dauer der aktuell aktiven Abfrage (in Sekunden).
- Warteereignistyp: Der gerade auftretende Warteereignistyp während der Ausführung der Abfrage, z. B. Zeitüberschreitung oder Sperre.
- Warteereignis: Das gerade auftretende Warteereignis während der Ausführung der Abfrage.
- Aktion: Mögliche Aktionen, z. B. Verbindung beenden.
Klicken Sie auf die Prozess-ID, die Sie untersuchen möchten, um sie zu maximieren. Sie können zugrunde liegende Prozesse im Untersuchungsbaum bis zu drei Ebenen tief aufschlüsseln.
- Prozess-ID: Die Prozess-ID der Abfrage. Klicken Sie auf
- Suchen Sie die blockierte Anfrage und klicken Sie auf Verbindung beenden. Nachdem Sie die Verbindung beendet haben, können Sie zu Cloud SQL Studio wechseln, um Ihre aktiven Abfragen noch einmal auszuführen.