Profila il tuo database

Misura le prestazioni del tuo Firebase Realtime Database con lo strumento di profilazione del database, integrato nella CLI di Firebase . Lo strumento di profilazione registra tutta l'attività nel tuo database in un determinato periodo di tempo, quindi genera un rapporto dettagliato. Utilizza il report 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 la versione più recente della CLI Firebase e di averla inizializzata per il database e il progetto che desideri profilare. Tieni presente che devi essere un editor o un proprietario del progetto per profilarlo.

  2. Inizia a profilare il tuo database con il seguente comando:

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

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

Interpreta i tuoi risultati

Lo strumento di profilazione 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 rapporto sulla velocità misura il tempo di risposta del server (in millisecondi) per ciascun tipo di operazione. Tuttavia, la velocità misurata nel Rapporto sulla velocità potrebbe non riflettere effettivamente la velocità sperimentata dagli utenti finali. Diversi fattori, incluse le condizioni della rete, possono aggiungere latenza sul lato client.

Il rapporto 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 secondari, lo strumento profiler li comprime in un percorso principale e aggiunge un indicatore di carattere $wildcard . Potresti vedere la directory principale del tuo database nel rapporto, rappresentata da una barra / .
  • Conteggio: il numero di operazioni che si sono verificate nel percorso specificato.
  • Velocità di esecuzione media: il tempo medio impiegato dal server per eseguire la logica aziendale necessaria per gestire il particolare tipo di operazione su quel percorso. L'intervallo di tempo qui misurato inizia dopo quello misurato dal "Tempo medio di attesa" descritto di seguito.
  • Tempo di attesa medio: il tempo medio trascorso dalle richieste in coda prima di essere eseguite. Questo ritardo è comune a tutte le richieste avviate dal client. La latenza totale della richiesta lato server corrisponde all'incirca alla 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 database.
Rapporto sulla velocità per tipo di operazione
Leggi Velocità di esecuzione Il tempo di risposta del server per le richieste del client di leggere i dati dal database. Il tempo di esecuzione della lettura generalmente varia in base alla quantità di dati letti, ma anche alcune letture di piccole dimensioni potrebbero essere ritardate dal precaricamento della cache.
Velocità di esecuzione della scrittura Il tempo di risposta del server per le richieste del client di scrivere dati nel database. I tempi di esecuzione della scrittura vengono scalati in base alla quantità di dati da scrivere.
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 della connessione.
Velocità di esecuzione della trasmissione

La quantità di tempo impiegata dal server per distribuire i dati ai client in ascolto sul percorso specificato per aggiornamenti in tempo reale.

La proprietà Count nel Report 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 trasmetteva un aggiornamento a tutti e 10 i client, il conteggio delle trasmissioni rifletterà 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 report 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 report 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 carico utile dei dati consumati dalle operazioni di lettura, scrittura e trasmissione da e verso il database. È uno strumento che misura le prestazioni, non 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 secondari, lo strumento profiler li comprime in un percorso principale.

  • Totale: il totale dei byte 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 inviati 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. Ciò utilizza più larghezza di banda del necessario. Risolvi quante più query non indicizzate possibile per ottimizzare le prestazioni del tuo database.

Il rapporto Query non indicizzate visualizza 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 Indicizzare i tuoi dati .
  • Conteggio: il numero di query non indicizzate che si sono verificate nel percorso specificato.

Profilazione avanzata

Per vedere tutte le operazioni gestite dal tuo database, usa il flag --raw quando profili il tuo database, come segue:

firebase database:profile --raw

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

Lo strumento di profilazione: non uno strumento di fatturazione

Non utilizzare lo strumento profiler per stimare il costo della larghezza di banda. Lo strumento di profilazione ha lo scopo di fornirti un quadro generale delle prestazioni del tuo 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 è coperto dal profilo del database:

  • Overhead del protocollo: è necessario un po' di 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. Anche se in genere non si tratta di una grande quantità di larghezza di banda, può essere notevole se i carichi utili sono piccoli o se si effettuano connessioni frequenti e brevi.
  • Sovraccarico di crittografia SSL: è previsto un costo associato al sovraccarico di crittografia SSL necessario per 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 fattura. Tuttavia, questa percentuale 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 fattura .