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 couche session (couche 5) du modèle OSI. Le stockage est facturé à 5 $ par Go/mois, évalué quotidiennement. La facturation n'est pas affectée par l'emplacement de votre base de données. Le trafic sortant inclut les frais généraux de connexion et de chiffrement de toutes les opérations de base de données et des données téléchargées via 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 les clients obtiennent des données à partir de votre base de données, Firebase facture les données téléchargées. En général, cela représente l'essentiel 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 gérer une session. En fonction du protocole sous-jacent, ce trafic peut inclure les coûts liés au protocole en temps réel de Firebase Realtime Database, aux coûts liés à WebSocket et aux coûts liés aux en-têtes 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 part importante de votre facture si vos charges utiles sont minuscules ou si vous effectuez des connexions courtes et fréquentes.
  • Coût du chiffrement SSL:un coût est associé au coût du chiffrement SSL nécessaire pour les connexions sécurisées. En moyenne, ce coût est d'environ 3, 5 ko pour la négociation initiale et d'environ 10 octets pour les en-têtes d'enregistrement TLS sur chaque message sortant. Pour la plupart des applications, il s'agit d'un faible pourcentage de votre facture. Toutefois, ce pourcentage peut être élevé si votre cas spécifique nécessite de nombreuses poignées de main SSL. Par exemple, les appareils qui ne sont pas compatibles avec les billets de session TLS peuvent nécessiter un grand nombre d'échanges 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 afficher vos connexions Realtime Database et votre utilisation des données actuelles, accédez à l'onglet Usage dans la console Firebase. Vous pouvez consulter la consommation au cours de la période de facturation en cours, des 30 derniers jours ou des 24 dernières heures.

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

  • Connexions:nombre de connexions simultanées, actuellement ouvertes et en temps réel à votre base de données. Cela inclut les connexions en temps réel suivantes: WebSocket, long polling et événements HTML envoyés par le serveur. 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 Firebase Hosting 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 les dépassements associés au protocole et au chiffrement.
  • Charge:ce graphique indique la quantité de votre base de données utilisée pour traiter des 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 les connexions ouvertes, ce qui réduit les coûts de chiffrement SSL qui s'accumulent généralement avec l'API REST.
  • Rechercher des bugs:si vos coûts de bande passante sont inattendus, 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 pour mesurer vos opérations de lecture et activez 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éduire les connexions:si possible, essayez d'optimiser la bande passante de votre connexion. Les requêtes REST fréquentes et de petite envergure 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 "keep-alive" HTTP ou des événements envoyés par le serveur, ce qui peut réduire les coûts liés aux poignées de main SSL.
  • Utilisez des tickets de session TLS:réduisez les coûts indirects du chiffrement SSL sur les connexions reprises en émettant des tickets de session TLS. Cela est particulièrement utile si vous avez besoin de connexions fréquentes et sécurisées à 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, ce qui 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 aussi loin que possible dans le chemin d'accès pour limiter la quantité de données qu'ils synchronisent.
  • Réduire 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.
  • 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 qu'un utilisateur malveillant ne télécharge à plusieurs reprises l'intégralité de votre base de données. Découvrez comment utiliser les règles Firebase Realtime Database.

Le meilleur plan d'optimisation pour votre application dépend de votre cas d'utilisation particulier. Bien que cette liste ne soit pas exhaustive, vous trouverez d'autres conseils et astuces des experts Firebase sur notre canal Slack ou sur Stack Overflow.