Per aiutarti a comprendere, ottimizzare e diagnosticare meglio i problemi relativi alle transazioni, Spanner ti consente di accedere alle statistiche di commit delle transazioni. Al momento, puoi recuperare il numero totale di modifiche per una transazione.
Quando utilizzare le statistiche sui commit
Conoscere il conteggio delle mutazioni per una transazione può essere utile nei seguenti scenari.
Ottimizzare per i viaggi di andata e ritorno
Per migliorare le prestazioni dell'applicazione, puoi ridurre il numero di round trip al database eseguendo il maggior numero possibile di operazioni in ogni transazione. In questo scenario, vuoi massimizzare il numero di mutazioni per transazione, rimanendo al contempo entro i limiti del sistema.
Per determinare quante righe puoi eseguire il commit per transazione rimanendo al di sotto del limite, esegui prima il commit di una riga in una transazione. In questo modo, ottieni una base di riferimento per il conteggio delle mutazioni per riga. Quindi dividi il limite di sistema per la base di riferimento per ottenere un numero di righe per transazione. Per ulteriori informazioni su come vengono conteggiate le mutazioni, consulta questa nota.
Tieni presente che l'ottimizzazione per i viaggi di andata e ritorno non è sempre vantaggiosa, soprattutto se comporta un maggior numero di contese dei blocchi. Puoi risolvere i conflitti di blocco nel tuo database utilizzando le statistiche sui blocchi.
Monitorare le transazioni per evitare di raggiungere i limiti del sistema
Man mano che l'utilizzo dell'applicazione aumenta, è possibile che aumenti anche il numero di mutazioni nella transazione. Per evitare di raggiungere il limite del sistema e che la transazione alla fine non vada a buon fine, puoi monitorare in modo proattivo la statistica di commit del conteggio delle mutazioni nel tempo. Se noti che questo valore aumenta per la stessa transazione, potrebbe essere il momento di ottimizzare nuovamente la transazione come descritto nella sezione precedente.
Come accedere alle statistiche sui commit
Le statistiche sui commit non vengono restituite per impostazione predefinita. Devi invece impostare il
flag return_commit_stats
su true in ogni CommitRequest. Se
il tentativo di commit supera il numero massimo consentito di mutazioni per una
transazione, il commit non va a buon fine e viene restituito un errore INVALID_ARGUMENT.
Ecco un esempio di come restituire le statistiche di commit utilizzando le librerie client Spanner.
Recuperare le statistiche di commit
Il seguente esempio mostra come ottenere le statistiche sui commit utilizzando le librerie client Spanner.
C++
Il seguente codice chiama set_return_stats()
su CommitOptions
e
restituisce un conteggio delle mutazioni pari a 6, perché inseriamo o aggiorniamo 2 righe e
3 colonne in ogni riga.
C#
In C#, le statistiche sui commit non vengono restituite direttamente tramite l'API. ma vengono registrati al livello di log Informazioni dal logger predefinito.
Il codice seguente attiva la registrazione delle statistiche di commit per tutte le transazioni impostando la proprietà LogCommitStats
su SpannerConnectionStringBuilder
su true. Il codice implementa anche un logger di esempio che mantiene un riferimento all'ultima risposta di commit visualizzata. MutationCount
viene quindi recuperato da questa
risposta e visualizzato.
Vai
Il seguente codice imposta il flag ReturnCommitStats
e stampa il conteggio delle mutazioni
quando la transazione viene eseguita correttamente.
Java
Node.js
Il seguente codice imposta il flag returnCommitStats
e restituisce un conteggio delle mutazioni pari a 6, perché stiamo inserendo o aggiornando 2 righe e 3 colonne in ogni riga.
PHP
Python
Anziché restituire le statistiche sui commit direttamente tramite l'API, la libreria client Python le registra utilizzando stdout
al livello Info
.
Il codice seguente attiva la registrazione delle statistiche di commit per tutte le transazioni impostando database.log_commit_stats = True
. Il codice implementa anche un
logger di esempio che mantiene un riferimento all'ultima risposta del commit visualizzata. Il
mutation_count
viene quindi recuperato da questa risposta e visualizzato.
Ruby
Il seguente codice imposta il flag return_commit_stats
e restituisce un conteggio delle mutazioni pari a 6, perché stiamo inserendo o aggiornando 2 righe e 3 colonne in ogni riga.