Google s'est engagé à promouvoir l'équité raciale pour les communautés noires. Regarde comment.
Cette page a été traduite par l'API Cloud Translation.
Switch to English

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 de 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. C'est une solution efficace et à 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 est recommandée par Firebase?

Votre choix de solution de base de données dépendra de nombreux facteurs, mais en ce qui concerne certaines fonctionnalités, nous pouvons vous recommander la base de données qui vous convient.

Les deux solutions offrent:

  • SDK axés sur le client, sans serveur à déployer et à maintenir
  • Mises à jour en temps réel
  • Niveau gratuit, puis payez 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 ...
Principalement la synchronisation des données, avec des requêtes de base.
Si vous n'avez pas besoin de requêtes avancées, de tri et de transactions, nous vous recommandons Realtime Database .
Interrogation, 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 enverra un flux de petites mises à jour, par exemple dans une application de tableau blanc numérique, nous vous recommandons Realtime Database .
Des centaines de Go à To de données qui 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 non structurées JSON, nous recommandons la base de données en temps réel .
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'au moins 99,95% de disponibilité.
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 fonctionnalités de requête sophistiquées sur les données locales lorsque l'utilisateur est hors ligne, nous recommandons Cloud Firestore .
Rarement ou jamais.
Si vous vous attendez à ce que vos utilisateurs soient constamment en ligne, nous vous recommandons Cloud Firestore ou Realtime Database .
Nombre d'instances de base de données
Dans mes projets individuels, j'ai besoin d'utiliser ...
De nombreuses bases de données, par exemple une base de données pour chaque client majeur.
Puisqu'il vous permet d'ajouter plusieurs bases de données à un seul projet Firebase, nous vous recommandons Realtime Database .
Juste une seule base de données.
Si vous avez besoin d'une seule base de données, nous vous recommandons Cloud Firestore ou Realtime Database .

Quels sont les autres éléments importants à considérer?

Après avoir réfléchi aux considérations clés précédentes, vous serez peut-être prêt à choisir une base de données . Si vous pesez toujours 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 dans une grande arborescence JSON.
  • Les données simples sont très faciles à stocker.
  • Les données complexes et hiérarchisées sont plus difficiles à organiser à grande échelle.

En savoir plus sur le modèle de données de la base de données en temps réel .

Stocke les données sous forme de collections de documents.
  • Les données simples sont faciles à stocker dans des documents, qui sont très similaires à JSON.
  • Les données complexes et hiérarchisées sont plus faciles à organiser à grande échelle, en utilisant des sous-collections dans les 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 pour mobile et prennent tous deux en charge le stockage de données local pour les applications prêtes pour le mode hors connexion.

Base de données en temps réel Cloud Firestore
Prise en charge hors ligne des clients iOS et Android. Prise en charge hors ligne des clients iOS, 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 la connexion du client et fournir des mises à jour chaque fois que l'état de la 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. Voir Créer une présence dans Cloud Firestore .

Requête

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 profondes par défaut: elles renvoient toujours la sous-arborescence entière.
  • 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; toutefois, 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 ne renvoient que 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.
  • Ecrivez 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 des données de manière atomique à partir de n'importe quelle partie de la base de données.

Fiabilité et performance

Base de données en temps réel Cloud Firestore
Realtime Database est une solution à une seule région.
  • Les bases de données sont limitées à la disponibilité zonale dans une seule région.
  • Latence extrêmement faible, option idéale pour une synchronisation d'état fréquente.
En savoir plus sur les performances et les caractéristiques de fiabilité de la base de données en temps réel dans l' accord de niveau de service .
Cloud Firestore est une solution 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 fiabilité élevée.
  • Disponible dans des configurations régionales ou multirégionales dans le monde entier.
En savoir plus sur les performances et la fiabilité de Cloud Firestore dans le contrat de niveau de service .

Évolutivité

Base de données en temps réel Cloud Firestore
La mise à l'échelle nécessite un partitionnement.
  • Évoluez jusqu'à environ 200 000 connexions simultanées et 1 000 écritures / seconde dans une seule base de données. Pour évoluer au-delà de cela, 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 complètement automatiquement. 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.
  • A des limites sur les taux d'écriture sur des documents ou des 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 combinant 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 des SDK de serveur sécurisés par Identity and Access Management (IAM) .
  • Les règles ne sont pas 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 peuvent contenir des données auxquelles l'utilisateur n'a pas accès, la requête entière échoue.

Tarification

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

Base de données en temps réel Cloud Firestore
Ne facture que la bande passante et le stockage , mais à un taux plus élevé.

En savoir plus sur les plans tarifaires de base de données en temps réel .

Frais principalement sur les opérations effectuées dans votre base de données (lecture, écriture, suppression) et, à moindre coût, sur la bande passante et le stockage.

Cloud Firestore prend en charge les limites de dépenses quotidiennes pour les projets Google 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 de Cloud Firestore .

Utilisation de Cloud Firestore et de 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 .

En savoir plus sur les fonctionnalités disponibles dans Realtime Database et Cloud Firestore .

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

Espérons que cette comparaison vous a aidé à vous installer sur une solution de base de données Firebase. Vous pouvez maintenant apprendre à ajouter une base de données à vos projets Firebase.