Questa pagina descrive come monitorare e risolvere i problemi relativi alle query attive nel database. Il monitoraggio di queste query può aiutare a identificare le cause della latenza del sistema e dell'utilizzo elevato della CPU.
Nella dashboard di Query Insights puoi visualizzare un riepilogo delle transazioni attive e un elenco di transazioni con query e statistiche associate. Le transazioni vengono visualizzate in base all'ora di inizio della transazione. Se è in esecuzione un numero elevato di query, i risultati potrebbero essere limitati a un sottoinsieme delle query totali.
Prima di iniziare
Per monitorare le query attive, puoi utilizzare la versione Cloud SQL Enterprise o Cloud SQL Enterprise Plus.
Per terminare una sessione o una transazione a lunga esecuzione nelle query attive, devi utilizzare la versione Cloud SQL Enterprise Plus per l'istanza Cloud SQL.
Per saperne di più sulle versioni di Cloud SQL, consulta Introduzione alle versioni di Cloud SQL.
Ruoli e autorizzazioni richiesti
Per ottenere le autorizzazioni necessarie per visualizzare le query attive, chiedi all'amministratore di concederti i seguenti ruoli IAM nel progetto che ospita l'istanza Cloud SQL:
-
Visualizza il riepilogo dell'attività dell'istanza:
Visualizzatore Cloud SQL (
roles/cloudsql.viewer) -
Visualizza il riepilogo dell'attività del database e le transazioni a lunga esecuzione:
Visualizzatore Database Insights (
roles/databaseinsights.viewer) -
Termina una sessione o una transazione a lunga esecuzione:
-
Editor Cloud SQL (
roles/cloudsql.editor) -
Amministratore delle operazioni di Database Insights (
roles/databaseinsights.operationsAdmin)
-
Editor Cloud SQL (
Per saperne di più sulla concessione dei ruoli, consulta Gestisci l'accesso a progetti, cartelle e organizzazioni.
Questi ruoli predefiniti contengono le autorizzazioni necessarie per visualizzare le query attive. Per vedere quali sono esattamente le autorizzazioni richieste, espandi la sezione Autorizzazioni obbligatorie:
Autorizzazioni obbligatorie
Per visualizzare le query attive sono necessarie le seguenti autorizzazioni:
-
Visualizza il riepilogo dell'attività del database e le transazioni a lunga esecuzione:
-
databaseinsights.activeQueries.fetch -
databaseinsights.activitySummary.fetch
-
Potresti anche ottenere queste autorizzazioni con ruoli personalizzati o altri ruoli predefiniti.
Abilita le query attive
Quando abiliti Query Insights, abiliti automaticamente le query attive. Per poter terminare una sessione o una transazione a lunga esecuzione nelle query attive, devi utilizzare Query Insights per la versione Cloud SQL Enterprise Plus.
Disabilita le query attive
Non puoi disabilitare le query attive senza disabilitare Query Insights. Per disabilitare le query attive e Query Insights, consulta Disabilita Query Insights.
Visualizza le query attive
Per visualizzare le query attive:
Nella Google Cloud console, vai alla pagina Istanze Cloud SQL.
Per aprire la pagina Panoramica di un'istanza, fai clic sul nome dell'istanza.
Esegui una delle seguenti operazioni per visualizzare la dashboard Query Insights:
- Seleziona la scheda Query Insights.
- Fai clic su Accedi a Query Insights per informazioni più approfondite su query e prestazioni. Viene visualizzata la dashboard Query Insights. Nella parte superiore vengono visualizzati i dettagli dell'istanza.
Fai clic sulla scheda Query attive.
Da qui, puoi modificare le informazioni sulle query visualizzate nella tabella Transazioni in esecuzione da più tempo:
- Database: filtra il carico delle query su un database specifico o su tutti i database.
- Utente: filtra il carico delle query da un account utente specifico.
Visualizza le query attive normalizzate
Puoi visualizzare un elenco delle principali transazioni a lunga esecuzione con query attive normalizzate nella dashboard Query Insights. Una query attiva normalizzata rimuove i dati sensibili e restituisce un digest. Il digest è lo stesso per i diversi valori utilizzati nel seguente esempio:
Query regolari
select * from test_table where id=1;select * from test_table_where id=2;
Digest o query normalizzata
select * from test_table where id=?;
Una query eseguita in sessioni diverse viene visualizzata come voci diverse nella dashboard.
Visualizza le principali transazioni in esecuzione da più tempo
La tabella Transazioni in esecuzione da più tempo nella dashboard Query Insights contiene le seguenti colonne:
| Nome colonna | Descrizione |
|---|---|
| ID sessione | Identificatore univoco della sessione. |
| Query | Testo della query SQL. |
| Stato sessione | Lo stato della sessione. |
| Durata query | Da quanto tempo è in esecuzione la query. |
| ID sessione di blocco | L'ID della sessione che blocca la sessione. |
| Tipo di evento di attesa | Il tipo di evento di attesa, se la richiesta è bloccata per l'esecuzione della query. |
| Risorsa in attesa | La risorsa per cui la richiesta è attualmente in attesa, se la richiesta è bloccata per l'esecuzione della query. |
| Durata attesa transazione | La durata dell'attesa corrente, se la sessione è bloccata. |
| Letture logiche | Il numero di letture logiche eseguite dalla richiesta. |
| Letture | Il numero di letture eseguite dalla richiesta. |
| Scritture | Il numero di scritture eseguite dalla richiesta. |
| Database | Database in cui è in esecuzione la sessione. |
| Utente | Nome dell'utente connesso al database. |
| Indirizzo client | L'indirizzo IP specifico del client che ha inviato una query. |
| Tempo di CPU (ms) | Il tempo di CPU in millisecondi utilizzato dalla richiesta. |
| Nome applicazione | Nome dell'applicazione che ha avviato la sessione. |
| Righe transazione modificate | Numero di righe restituite al client da questa query. |
| % di completamento | Percentuale di lavoro completato, se la query segnala l'avanzamento. |
| Memoria query concessa | Il numero di pagine allocate all'esecuzione della richiesta. |
| Azione | Contiene un link per terminare una sessione. |
La visualizzazione viene aggiornata automaticamente ogni 60 secondi.
Puoi utilizzare il Opzioni di visualizzazione dei contenuti... menu verticale per filtrare le colonne che vuoi visualizzare.
Termina una sessione
Per terminare una sessione o una transazione a lunga esecuzione, devi utilizzare la versione Cloud SQL Enterprise Plus e abilitare Query Insights per la versione Cloud SQL Enterprise Plus.
Le operazioni a lunga esecuzione possono richiedere più tempo per essere terminate.
Per terminare una query o una transazione:
- Nella tabella Transazioni in esecuzione da più tempo, seleziona una query.
- Nella colonna Azione, fai clic su Termina sessione.
- Nella finestra Termina sessione, fai clic su Conferma.