Comprendre la facturation des bases de données en temps réel

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 couche de session (couche 5) du modèle OSI. Le stockage est facturé 5 $ pour chaque Go/mois, é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 les données téléchargées via les lectures de base de données. Les lectures et écritures de la 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 les clients obtiennent des données de votre base de données, Firebase facture les données téléchargées. En règle générale, cela représente l'essentiel de vos coûts de bande passante, mais ce n'est pas le seul facteur pris en compte dans votre facture.
  • Surcharge de 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 de WebSocket et la surcharge de l'en-tête HTTP. Chaque fois qu'une connexion est établie, cette surcharge, combinée à toute surcharge 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 partie importante de votre facture si vos charges utiles sont minuscules ou si vous établissez des connexions fréquentes et courtes.
  • Surcharge de chiffrement SSL : il existe un coût associé à la surcharge de cryptage SSL nécessaire pour les connexions sécurisées. En moyenne, ce coût est d'environ 3,5 Ko pour la prise de contact initiale et d'environ plusieurs dizaines d'octets pour les en-têtes d'enregistrement TLS sur chaque message sortant. Pour la plupart des applications, cela représente un petit pourcentage de votre facture. Cependant, cela peut devenir un pourcentage important si votre cas spécifique nécessite de nombreuses négociations SSL. Par exemple, les appareils qui ne prennent pas en charge les tickets de session TLS peuvent nécessiter un grand nombre d’établissements de liaison 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 de la base de données en temps réel, Firebase facture les données que vous lisez et écrivez à partir de la console Firebase.

Estimez votre consommation facturée

Pour voir vos connexions actuelles à la base de données en temps réel et votre utilisation des données, consultez l'onglet Utilisation dans la console Firebase. Vous pouvez vérifier l'utilisation sur la période de facturation en cours, les 30 derniers jours ou les dernières 24 heures.

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

  • Connexions : nombre de connexions simultanées, actuellement ouvertes, en temps réel à votre base de données. Cela inclut les connexions en temps réel suivantes : WebSocket, interrogations longues 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. Cela n'inclut pas l'hébergement Firebase ni les données 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 la surcharge de protocole et de chiffrement.
  • Charge : ce graphique montre la quantité de votre base de données utilisée, traitant les requêtes, sur un intervalle donné d'une minute. Vous pourriez rencontrer des problèmes de performances lorsque votre base de données approche 100 %.

Optimiser l'utilisation

Il existe quelques bonnes pratiques que vous pouvez utiliser 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 plateforme de votre application, au lieu de l'API REST. Les SDK maintiennent des connexions ouvertes, réduisant ainsi les coûts de chiffrement SSL qui s'ajoutent généralement à l'API REST.
  • Recherchez les bugs : si vos coûts de bande passante sont étonnamment élevés, vérifiez que votre application ne synchronise pas plus de données ou ne se synchronise pas plus souvent que prévu initialement. Pour identifier les problèmes, utilisez l' outil de profilage pour mesurer vos opérations de lecture et activer la journalisation de débogage dans les SDK Android , Objective-C et Web . Vérifiez les processus en arrière-plan et de synchronisation dans votre application pour vous assurer que tout fonctionne comme prévu.
  • Réduisez les connexions : si possible, essayez d’optimiser la bande passante de votre connexion. De petites requêtes REST fréquentes peuvent s'avérer plus coûteuses qu'une connexion unique et continue utilisant le SDK natif. Si vous utilisez l'API REST, envisagez d'utiliser un HTTP keep-alive ou des événements envoyés par le serveur , ce qui peut réduire les coûts liés aux négociations SSL.
  • Utilisez des tickets de session TLS : réduisez les coûts de chiffrement SSL lors de la reprise des connexions en émettant des tickets de session TLS . Ceci est particulièrement utile si vous avez besoin de connexions fréquentes et sécurisées à la base de données.
  • Requêtes d'indexation : l'indexation de vos données réduit la bande passante totale que vous utilisez pour les requêtes, ce qui présente le double avantage de réduire vos coûts et d'augmenter les performances de votre base de données. Utilisez l'outil de profilage pour rechercher des 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 téléchargent uniquement les mises à jour des données, par exemple, on() au lieu de once() . De plus, placez vos auditeurs aussi loin que possible pour limiter la quantité de données qu'ils synchronisent.
  • Réduisez les coûts de stockage : exécutez des tâches de nettoyage périodiques et réduisez les données en double dans votre base de données.
  • Utiliser des règles : empêchez toute opération potentiellement coûteuse et non autorisée sur votre base de données. Par exemple, l'utilisation des règles de sécurité de la base de données en temps réel Firebase pourrait é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 de base de données en temps réel Firebase .

Le meilleur plan d'optimisation pour votre application dépend de votre cas d'utilisation particulier. Bien qu'il ne s'agisse pas d'une liste exhaustive des bonnes pratiques, vous pouvez trouver plus de conseils et d'astuces de la part des experts Firebase sur notre chaîne Slack ou sur Stack Overflow .