Choisissez une base de données : Cloud Firestore ou Realtime Database

Firebase propose deux solutions de base de données basées sur le cloud et accessibles au client qui prennent en charge la synchronisation des données en temps réel :

  • Cloud Firestore est la dernière base de données Firebase pour le développement d'applications mobiles. Il s'appuie sur les succès de la base de données en temps réel avec un nouveau modèle de données plus intuitif. Cloud Firestore propose également des requêtes plus riches et plus rapides et évolue plus loin que la base de données en temps réel.

  • Realtime Database est la base de données originale de Firebase. Il s'agit d'une solution efficace à faible latence pour les applications mobiles qui nécessitent des états synchronisés entre les clients en temps réel.

Quelle base de données Firebase recommande-t-il ?

Votre choix de solution de base de données dépendra de nombreux facteurs, mais lorsqu'il s'agit de certaines fonctionnalités, nous pouvons vous faire des recommandations sur la base de données qui vous convient le mieux.

Les deux solutions offrent :

  • SDK axés sur le client, sans serveurs à déployer et à entretenir
  • Mises à jour en temps réel
  • Niveau gratuit, puis payez pour ce que vous utilisez

Considérations clés

Au-delà des fonctionnalités de base communes aux deux bases de données, réfléchissez à la manière dont tout ou partie des considérations énumérées ci-dessous affecteront le succès de vos applications.

Rôle de la base de données
Mon application utilise une base de données pour...
Synchronisation principalement des données, avec requêtes de base.
Si vous n'avez pas besoin de requêtes, de tris et de transactions avancés, nous vous recommandons Realtime Database .
Requêtes, tri et transactions avancés.
Si vous avez besoin d'interactions complexes avec vos données, par exemple dans les applications de commerce électronique, nous vous recommandons Cloud Firestore .
Opérations sur les données
L'utilisation de la base de données de mon application ressemble à...
Quelques Go ou moins de données qui changent fréquemment.
Si votre application doit envoyer un flux de petites mises à jour, comme dans une application de tableau blanc numérique, nous recommandons Realtime Database .
Des centaines de Go à des To de données sont lues beaucoup plus souvent qu'elles ne sont modifiées.
Pour les ensembles de données très volumineux et lorsque des opérations par lots sont fréquemment nécessaires, nous recommandons Cloud Firestore .
Modèle de données
Je préfère structurer mes données comme...
Un simple arbre JSON.
Pour les données JSON non structurées, nous recommandons Realtime Database .
Documents organisés en collections.
Pour les documents et collections structurés, nous recommandons Cloud Firestore .
Disponibilité
Mes besoins en disponibilité sont...
Garantie de disponibilité extrêmement élevée de 99,999 %.
Si la disponibilité est de la plus haute importance, par exemple dans les applications de commerce électronique, nous recommandons Cloud Firestore .
Une garantie d’une disponibilité d’au moins 99,95 %.
Lorsqu'une disponibilité très élevée mais non critique est acceptable, nous recommandons Cloud Firestore ou Realtime Database .
Requêtes hors ligne sur des données locales
Mon application devra effectuer des requêtes sur des appareils avec une connectivité limitée ou inexistante...
Fréquemment.
Pour des capacités d'interrogation sophistiquées sur les données locales lorsque l'utilisateur est hors ligne, nous recommandons Cloud Firestore .
Rarement ou jamais.
Si vous souhaitez que vos utilisateurs soient constamment en ligne, nous recommandons Cloud Firestore ou Realtime Database .

Quels sont les autres éléments importants à prendre en compte ?

Après avoir réfléchi aux considérations clés précédentes, vous pourriez être prêt à choisir une base de données . Si vous pesez encore le pour et le contre, cette section couvre d'autres différences entre Cloud Firestore et Realtime Database.

Modèle de données

Realtime Database et Cloud Firestore sont des bases de données NoSQL.

Base de données en temps réel Cloud Firestore
Stocke les données sous la forme d'une grande arborescence JSON.
  • Les données simples sont très faciles à stocker.
  • Les données complexes et hiérarchiques sont plus difficiles à organiser à grande échelle.

En savoir plus sur le modèle de données Realtime Database .

Stocke les données sous forme de collections de documents.
  • Les données simples sont faciles à stocker dans des documents très similaires à JSON.
  • Les données complexes et hiérarchiques sont plus faciles à organiser à grande échelle, en utilisant des sous-collections au sein des documents.
  • Nécessite moins de dénormalisation et d’aplatissement des données.

En savoir plus sur le modèle de données Cloud Firestore .

Assistance en temps réel et hors ligne

Les deux disposent de SDK en temps réel axés sur les mobiles et prennent tous deux en charge le stockage de données local pour les applications prêtes à être utilisées hors ligne.

Base de données en temps réel Cloud Firestore
Prise en charge hors ligne pour les clients Apple et Android. Prise en charge hors ligne pour les clients Apple, Android et Web.

Présence

Il peut être utile de savoir quand un client est en ligne ou hors ligne. Firebase Realtime Database peut enregistrer l'état de connexion du client et fournir des mises à jour chaque fois que l'état de connexion du client change.

Base de données en temps réel Cloud Firestore
Présence prise en charge. Non pris en charge nativement. Vous pouvez tirer parti de la prise en charge de la présence par Realtime Database en synchronisant Cloud Firestore et Realtime Database à l'aide de Cloud Functions. Consultez Renforcer votre présence dans Cloud Firestore .

Interrogation

Récupérez, triez et filtrez les données de l'une ou l'autre base de données via des requêtes.

Base de données en temps réel Cloud Firestore
Requêtes approfondies avec des fonctionnalités de tri et de filtrage limitées.
  • Les requêtes peuvent trier ou filtrer sur une propriété, mais pas les deux.
  • Les requêtes sont approfondies par défaut : elles renvoient toujours l'intégralité du sous-arbre.
  • Les requêtes peuvent accéder aux données avec n'importe quelle granularité, jusqu'aux valeurs individuelles des nœuds feuilles dans l'arborescence JSON.
  • Les requêtes ne nécessitent pas d'index ; cependant, les performances de certaines requêtes se dégradent à mesure que votre ensemble de données augmente.
Requêtes indexées avec tri et filtrage composés.
  • Vous pouvez chaîner des filtres et combiner le filtrage et le tri sur une propriété dans une seule requête.
  • Les requêtes sont superficielles : elles renvoient uniquement les documents d'une collection ou d'un groupe de collections particulier et ne renvoient pas de données de sous-collection.
  • Les requêtes doivent toujours renvoyer des documents entiers.
  • Les requêtes sont indexées par défaut : les performances des requêtes sont proportionnelles à la taille de votre ensemble de résultats, et non à votre ensemble de données.

Écritures et transactions

Base de données en temps réel Cloud Firestore
Opérations d’écriture et de transaction de base. Opérations avancées d’écriture et de transaction.
  • Écrivez des opérations de données via des opérations de définition et de mise à jour ainsi que des transformations avancées telles que des opérateurs de tableau et numériques.
  • Les transactions peuvent lire et écrire atomiquement des données à partir de n'importe quelle partie de la base de données.

Fiabilité et performances

Base de données en temps réel Cloud Firestore
Realtime Database est une solution régionale.
  • Disponible dans des configurations régionales. Les bases de données sont limitées à la disponibilité zonale au sein d’une région.
  • Latence extrêmement faible, option idéale pour une synchronisation d'état fréquente.
Pour en savoir plus sur les performances et les caractéristiques de fiabilité de la base de données en temps réel, consultez l' accord de niveau de service .
Cloud Firestore est une solution régionale et multirégionale qui évolue automatiquement.
  • Héberge vos données dans plusieurs centres de données dans des régions distinctes, garantissant une évolutivité mondiale et une grande fiabilité.
  • Disponible dans des configurations régionales ou multirégionales dans le monde entier.
En savoir plus sur les caractéristiques de performances et de fiabilité de Cloud Firestore dans l' accord de niveau de service .

Évolutivité

Base de données en temps réel Cloud Firestore
La mise à l’échelle nécessite un partitionnement.
  • Adaptez-vous à environ 200 000 connexions simultanées et 1 000 écritures/seconde dans une seule base de données. Pour aller au-delà, vous devez partager vos données sur plusieurs bases de données.
  • Aucune limite locale sur les taux d’écriture sur des éléments de données individuels.
La mise à l'échelle est automatique.
  • Échelle entièrement automatique. Actuellement, les limites de mise à l'échelle sont d'environ 1 million de connexions simultanées et 10 000 écritures/seconde. Nous prévoyons d'augmenter ces limites à l'avenir.
  • Possède des limites sur les taux d'écriture sur des documents ou index individuels.

Sécurité

Base de données en temps réel Cloud Firestore
Langage de règles en cascade qui sépare l'autorisation et la validation. Règles non en cascade qui combinent autorisation et validation.
  • Lit et écrit à partir de SDK mobiles sécurisés par les règles de sécurité Cloud Firestore .
  • Lit et écrit à partir de SDK de serveur sécurisés par Identity and Access Management (IAM) .
  • Les règles ne sont pas appliquées en cascade, sauf si vous utilisez un caractère générique.
  • Les règles peuvent limiter les requêtes : si les résultats d'une requête contiennent des données auxquelles l'utilisateur n'a pas accès, la requête entière échoue.

Tarifs

Les deux solutions sont disponibles sur les plans tarifaires Spark et Blaze .

Base de données en temps réel Cloud Firestore
Frais uniquement pour la bande passante et le stockage , mais à un tarif plus élevé.

En savoir plus sur les plans tarifaires de Realtime Database .

Facture principalement sur les opérations effectuées dans votre base de données (lecture, écriture, suppression) et, à un tarif inférieur, sur la bande passante et le stockage.

Cloud Firestore prend en charge les limites de dépenses quotidiennes pour les projets App Engine, afin de vous assurer de ne pas dépasser les coûts avec lesquels vous êtes à l'aise.

En savoir plus sur les plans tarifaires Cloud Firestore .

Utiliser Cloud Firestore et la base de données en temps réel

Vous pouvez utiliser les deux bases de données dans la même application ou projet Firebase. Les deux bases de données NoSQL peuvent stocker les mêmes types de données et les bibliothèques clientes fonctionnent de la même manière. Gardez à l'esprit les différences décrites ci-dessus si vous décidez d' utiliser les deux bases de données dans votre application .

Apprenez-en davantage sur les fonctionnalités disponibles dans Realtime Database et Cloud Firestore .

Prêt à choisir une base de données ?

J'espère que cette comparaison vous a aidé à choisir une solution de base de données Firebase. Vous pouvez désormais apprendre à ajouter une base de données à vos projets Firebase.