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 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 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 des 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. Selon le 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 de l'en-tête HTTP. Chaque fois qu'une connexion est établie, ces frais généraux, combinés à tout frais généraux de chiffrement SSL, contribuent 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.
- Frais de chiffrement SSL:une surcharge de chiffrement SSL est associée à un coût, nécessaire au maintien des connexions sécurisées. En moyenne, ce coût est d'environ 3, 5 Ko pour le handshake initial et environ plusieurs dizaines d'octets pour les en-têtes d'enregistrement TLS pour chaque message sortant. Pour la plupart des applications, il s'agit d'un faible pourcentage de votre facture. Toutefois, ce pourcentage peut s'avérer important si votre cas spécifique nécessite de nombreuses handshakes 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 l'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 vérifier l'utilisation sur la période de facturation en cours, les 30 derniers jours ou les dernières 24 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 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 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 des requêtes sur un intervalle d'une minute donné. Il se peut que vous constatiez des problèmes de performances lorsque votre base de données approche des 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.
- 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 petites requêtes REST fréquentes et petites peuvent s'avérer plus coûteuses qu'une seule connexion 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 deonce()
). 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 un scénario dans lequel un utilisateur malveillant télécharge de façon répétée la totalité 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.