Comprendre la facturation Realtime Database

Firebase facture les données que vous stockez dans votre base de données et tout le trafic réseau sortant au niveau de la session (niveau 5) du modèle OSI. Le stockage est facturé 5 $ par Go et par mois, et évalué quotidiennement. La facturation n'est pas affectée par l'emplacement de votre base de données. Le trafic sortant inclut la surcharge de connexion et de chiffrement de toutes les opérations de base de données et des données téléchargées lors des lectures de base de données. Les lectures et les écritures de base de données peuvent entraîner des frais de connexion sur votre facture. Tout le trafic vers et depuis votre base de données, y compris les opérations refusées par les règles de sécurité, entraîne des coûts facturables.

Voici quelques exemples courants de trafic facturé :

  • Données téléchargées : lorsque des clients obtiennent des données de votre base de données, Firebase facture les données téléchargées. En général, cela représente la majeure partie de vos coûts de bande passante, mais ce n'est pas le seul facteur de votre facture.
  • Surcharge du protocole : un trafic supplémentaire entre le serveur et les clients est nécessaire pour établir et maintenir une session. En fonction du protocole sous-jacent, ce trafic peut inclure la surcharge du protocole en temps réel de Firebase Realtime Database, la surcharge WebSocket et la surcharge des en-têtes HTTP. Chaque fois qu'une connexion est établie, ce coût indirect, combiné à tout coût indirect de chiffrement SSL, contribue aux coûts de connexion. Bien que cela ne représente pas beaucoup de bande passante pour une seule requête, cela peut représenter une part importante de votre facture si vos charges utiles sont minuscules ou si vous établissez des connexions courtes et fréquentes.
  • Surcharge du chiffrement SSL : le chiffrement SSL nécessaire pour les connexions sécurisées entraîne un coût. En moyenne, ce coût est d'environ 3, 5 Ko pour la première prise de contact et d'environ quelques dizaines d'octets pour les en-têtes d'enregistrement TLS sur chaque message sortant. Pour la plupart des applications, cela représente un faible pourcentage de votre facture. Toutefois, cela peut représenter un pourcentage important si votre cas spécifique nécessite de nombreux handshakes SSL. Par exemple, les appareils qui ne sont pas compatibles avec les tickets de session TLS peuvent nécessiter un grand nombre de handshakes de connexion SSL.
  • Données de la console Firebase : bien que cela ne représente généralement pas une part importante des coûts Realtime Database, Firebase facture les données que vous lisez et écrivez à partir de la console Firebase.

Estimer votre utilisation facturée

Pour consulter vos connexions Realtime Database actuelles et votre utilisation des données, accédez à l'onglet Utilisation de la console Firebase. Vous pouvez vérifier l'utilisation au cours de la période de facturation actuelle, des 30 derniers jours ou des dernières 24 heures.

Firebase affiche des statistiques d'utilisation pour les métriques suivantes :

  • Connexions : nombre de connexions simultanées en temps réel actuellement ouvertes à votre base de données. Cela inclut les connexions en temps réel suivantes : WebSocket, long polling et événements envoyés par le serveur HTML. Il n'inclut pas les requêtes RESTful.
  • Stockage : quantité de données stockées dans votre base de données. Cette valeur n'inclut pas les données Firebase Hosting, ni celles stockées via d'autres produits Firebase.
  • Téléchargements : tous les octets téléchargés à partir de votre base de données, y compris les dépassements associés au protocole et au chiffrement.
  • Charge : ce graphique indique la part de votre base de données utilisée pour traiter les requêtes sur un intervalle d'une minute donné. Vous pouvez constater des problèmes de performances lorsque votre base de données approche les 100 %.

Optimiser l'utilisation

Vous pouvez appliquer quelques bonnes pratiques pour optimiser l'utilisation de votre base de données et les coûts de bande passante.

  • Utilisez les SDK natifs : dans la mesure du possible, utilisez les SDK qui correspondent à la plate-forme de votre application, plutôt que l'API REST. Les SDK maintiennent des connexions ouvertes, ce qui réduit les coûts de chiffrement SSL qui s'accumulent généralement avec l'API REST.
  • Recherchez les bugs : si vos coûts de bande passante sont anormalement élevés, vérifiez que votre application ne synchronise pas plus de données ou plus souvent que prévu. Pour identifier les problèmes, utilisez l'outil de profilage afin de mesurer vos opérations de lecture et d'activer la journalisation du débogage dans les SDK Android, Objective-C et Web. Vérifiez les processus d'arrière-plan et de synchronisation dans votre application pour vous assurer que tout fonctionne comme prévu.
  • Réduisez le nombre de connexions : si possible, essayez d'optimiser la bande passante de votre connexion. Les petites requêtes REST fréquentes peuvent être plus coûteuses qu'une connexion unique et continue à l'aide du SDK natif. Si vous utilisez l'API REST, envisagez d'utiliser un HTTP keep-alive ou des événements envoyés par le serveur, qui peuvent réduire les coûts liés aux négociations SSL.
  • Utiliser des tickets de session TLS : réduisez les coûts généraux de chiffrement SSL sur les connexions reprises en émettant des tickets de session TLS. Cela s'avère particulièrement utile si vous avez besoin de connexions sécurisées fréquentes à la base de données.
  • Requêtes d'index : l'indexation de vos données réduit la bande passante totale que vous utilisez pour les requêtes. Cela présente un double avantage : réduire vos coûts et améliorer les performances de votre base de données. Utilisez l'outil de profilage pour trouver les requêtes non indexées dans votre base de données.
  • Optimisez vos écouteurs : ajoutez des requêtes pour limiter les données renvoyées par vos opérations d'écoute et utilisez des écouteurs qui ne téléchargent que les mises à jour des données (par exemple, on() au lieu de once()). De plus, placez vos écouteurs le plus loin possible sur le chemin d'accès pour limiter la quantité de données qu'ils synchronisent.
  • Réduisez les coûts de stockage : exécutez des jobs de nettoyage périodiques et réduisez les données en double dans votre base de données.
  • Utilisez des règles : évitez toute opération non autorisée et potentiellement coûteuse sur votre base de données. Par exemple, l'utilisation de Firebase Realtime Database Security Rules peut éviter un scénario dans lequel un utilisateur malveillant télécharge à plusieurs reprises l'intégralité de votre base de données. En savoir plus sur l'utilisation des règles Firebase Realtime Database

Le plan d'optimisation le plus adapté à votre application dépend de votre cas d'utilisation spécifique. Cette liste de bonnes pratiques n'est pas exhaustive. Vous trouverez d'autres conseils et astuces auprès des experts Firebase sur notre chaîne Slack ou sur Stack Overflow.