Profila il tuo database

Misura le prestazioni del tuo Firebase Realtime Database con lo strumento di profilazione del database, integrato nell'interfaccia a riga di comando di Firebase . Lo strumento profiler registra tutte le attività nel database in un determinato periodo di tempo, quindi genera un rapporto dettagliato. Utilizza il rapporto dettagliato per risolvere i problemi relativi alle prestazioni del database, individuare le aree problematiche e ridurre le query non indicizzate.

Costruisci un profilo

  1. Prima di iniziare a profilare il tuo Firebase Realtime Database, assicurati di utilizzare l'ultima versione dell'interfaccia a riga di comando di Firebase e di averla inizializzata per il database e il progetto che desideri profilare. Tieni presente che devi essere un editore o proprietario di quel progetto per profilare.

  2. Avviare la profilazione del database con il seguente comando:

    firebase database:profile
    Il profiler visualizza un messaggio di stato mentre registra le operazioni dal database e crea il profilo.

  3. Premere Invio per completare il profilo e visualizzare i risultati.

Interpreta i tuoi risultati

Lo strumento profiler aggrega i dati raccolti sulle operazioni del database e visualizza i risultati in tre categorie principali: velocità , larghezza di banda e query non indicizzate .

Velocità

Il report sulla velocità misura il tempo di risposta del server (in millisecondi) per ogni tipo di operazione. Tuttavia, la velocità misurata nel report sulla velocità potrebbe non riflettere effettivamente la velocità percepita dagli utenti finali. Diversi fattori, incluse le condizioni della rete, possono aggiungere latenza sul lato client.

Il report sulla velocità include le seguenti proprietà:

  • Percorso: il percorso nel database in cui si sono verificate le operazioni. Se sono presenti più di 25 nodi figlio, lo strumento profiler li comprime in un percorso padre e aggiunge un indicatore $wildcard . Potresti vedere la directory principale del tuo database nel report, rappresentata da una barra / .
  • Conteggio: il numero di operazioni che si sono verificate nel percorso specificato.
  • Velocità media di esecuzione: il tempo medio impiegato dal server per eseguire la logica di business necessaria per gestire il particolare tipo di operazione in quel percorso. L'intervallo di tempo misurato qui inizia dopo quello misurato dal "Tempo di attesa medio" descritto di seguito.
  • Tempo medio di attesa: il tempo medio che le richieste trascorrono in coda prima di essere eseguite. Questo ritardo è comune a tutte le richieste avviate dal client. La latenza totale della richiesta lato server è approssimativamente la somma del tempo di attesa e della velocità di esecuzione della richiesta.
  • Autorizzazione negata: il numero di operazioni nel percorso specificato che sono state bloccate dalle regole del database Firebase sul tuo database.
Rapporto sulla velocità per tipo di operazione
Leggere la velocità di esecuzione Il tempo di risposta del server per le richieste del client per leggere i dati dal database. Il tempo di esecuzione della lettura generalmente si adatta alla quantità di dati letti, ma anche alcune piccole letture possono essere ritardate dal precaricamento della cache.
Scrivi la velocità di esecuzione Il tempo di risposta del server per le richieste del client di scrivere dati nel database. Il tempo di esecuzione della scrittura si adatta alla quantità di dati scritti.
Connetti la velocità di esecuzione Il tempo di risposta del server per le richieste da stabilire ai client del database. La latenza per le richieste di connessione è dominata dalla contabilità lato server in memoria relativa alla gestione delle connessioni.
Velocità di esecuzione della trasmissione

La quantità di tempo impiegata dal server per distribuire i dati ai client che ascoltano il percorso specificato per gli aggiornamenti in tempo reale.

La proprietà Count nel rapporto sulla velocità di trasmissione aggrega il numero di trasmissioni avvenute, non il numero di client che hanno ricevuto le informazioni. Ad esempio, se 10 client erano in ascolto su un determinato percorso e il server ha trasmesso un aggiornamento a tutti e 10 i client, il conteggio delle trasmissioni riflette solo 1 trasmissione, anche se 10 client hanno ricevuto i dati.

La proprietà Autorizzazione negata non è inclusa nel report Velocità di trasmissione.

Larghezza di banda

Il rapporto sulla larghezza di banda fornisce informazioni sulla quantità di dati consumati dal database durante le operazioni in entrata e in uscita. Tuttavia, non dovresti utilizzare il rapporto sulla larghezza di banda per stimare la fatturazione, perché non include la larghezza di banda utilizzata per altre operazioni, come la profilazione del database. Il rapporto sulla larghezza di banda stima approssimativamente la dimensione del payload dei dati consumati dalle operazioni di lettura, scrittura e trasmissione da e verso il database. È uno strumento che misura le prestazioni, non uno che prevede la fatturazione.

Il rapporto sulla larghezza di banda include le seguenti proprietà:

  • Percorso: il percorso nel database in cui si sono verificate le operazioni. Se sono presenti più di 25 nodi figlio, lo strumento profiler li comprime in un percorso padre.

  • Totale: i byte totali in uscita o in entrata utilizzati in tutte le operazioni nel percorso specificato.

  • Conteggio: il numero di operazioni che si sono verificate nel percorso specificato.

  • Media: il numero medio di byte scaricati o caricati tra le operazioni nel percorso specificato (byte/scrittura o byte/lettura).

Rapporto sulla larghezza di banda
Byte scaricati Dati consumati tramite operazioni di lettura e trasmissione inviate tramite gli SDK client e l'API REST.
Byte caricati Dati consumati tramite richieste di scrittura in arrivo nel server del database. Le eliminazioni vengono visualizzate come scritture con 0 byte in entrata.

Query non indicizzate

Le query non indicizzate possono essere costose, perché i client scaricano tutti i dati in una posizione e quindi eseguono query su di essi. Questo utilizza più larghezza di banda del necessario. Risolvi il maggior numero possibile di query non indicizzate per ottimizzare le prestazioni del tuo database.

Il rapporto Query non indicizzate mostra le seguenti proprietà:

  • Percorso: il percorso nel database in cui si sono verificate le query non indicizzate.
  • Indice: la regola da aggiungere per risolvere le query non indicizzate. Scopri di più sull'indicizzazione in Indicizza i tuoi dati .
  • Conteggio: il numero di query non indicizzate che si sono verificate nel percorso specificato.

Profilazione avanzata

Per vedere tutte le operazioni che il tuo database sta gestendo, usa il flag --raw quando crei il profilo del tuo database, come segue:

firebase database:profile --raw

L'output non elaborato include anche le informazioni sul client per ciascuna operazione, ad esempio le stringhe userAgent e gli indirizzi IP. Scopri di più sulle diverse operazioni profilate nel tuo Firebase Realtime Database in Firebase Realtime Database Operation Types .

Lo strumento profiler: non uno strumento di fatturazione

Non utilizzare lo strumento profiler per stimare il costo della larghezza di banda. Lo strumento profiler ha lo scopo di fornire un quadro generale delle prestazioni del database, per aiutarti a monitorare le operazioni e risolvere i problemi, non per stimare la fatturazione. Non tiene conto del traffico di rete, registra solo una stima dei dati dell'applicazione inviati nelle risposte.

Di seguito sono riportati alcuni esempi comuni di traffico di rete fatturato da Firebase che non sono inclusi nel profilo del database:

  • Overhead del protocollo: è necessario del traffico aggiuntivo tra il server e i client per stabilire e mantenere una sessione. A seconda del protocollo sottostante, questo traffico potrebbe includere: sovraccarico del protocollo in tempo reale di Firebase Realtime Database, sovraccarico di WebSocket e sovraccarico dell'intestazione HTTP. Ogni volta che viene stabilita una connessione, questo sovraccarico, combinato con qualsiasi sovraccarico di crittografia SSL, contribuisce ai costi di connessione. Sebbene in genere non si tratti di una grande quantità di larghezza di banda, può essere sostanziale se i tuoi payload sono piccoli o effettui connessioni frequenti e brevi.
  • Overhead di crittografia SSL: esiste un costo associato all'overhead di crittografia SSL necessario per le connessioni sicure. In media, questo costo è di circa 3,5 KB per l'handshake iniziale e di circa 40 miliardi per le intestazioni dei record TLS su ciascun messaggio in uscita. Per la maggior parte delle app, si tratta di una piccola percentuale della bolletta. Tuttavia, questa potrebbe diventare una percentuale elevata se il tuo caso specifico richiede molti handshake SSL. Ad esempio, i dispositivi che non supportano i ticket di sessione TLS potrebbero richiedere un numero elevato di handshake di connessione SSL.

Ulteriori informazioni su come comprendere e stimare la bolletta .