Monitorare le query attive

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:

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:

  1. Nella Google Cloud console, vai alla pagina Istanze Cloud SQL.

    Vai a Istanze Cloud SQL

  2. Per aprire la pagina Panoramica di un'istanza, fai clic sul nome dell'istanza.

  3. 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.
  4. 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:

  1. Nella tabella Transazioni in esecuzione da più tempo, seleziona una query.
  2. Nella colonna Azione, fai clic su Termina sessione.
  3. Nella finestra Termina sessione, fai clic su Conferma.

Passaggi successivi