How to create multi environment DB's with Firestore
Asked Answered
B

4

40

I've been looking at how to create multiple Firestore instances in Firebase, I need different Db's for prod, staging and development. I read the documentation and seems that I only need to modify the "Google-services.json" file in the applications. what I don't get is what should I modify and how that would look in the console.

  • Am I going to see different instances in the same project?

  • I need to create different projects for every environment and modify those values in the file?

  • If I need to test something that requires testing in all environments and all of them require Blaze to run that test do I have to pay Triple?

Thanks in advance

Brothers answered 6/2, 2018 at 17:54 Comment(0)
C
29

Firebase doesn't support the use of multiple Firestore instances in a single project.

The Firebase team strongly recommends creating different projects for each of your environments to keep them separate. This probably means you will have to build different apps that each point to different instances, or you will have to somehow configure your app at runtime to select which project you want to work with.

There is no obligation to add billing to any of the projects you don't want to pay for, as long as you accept the limitations of the Spark plan.

Cymry answered 6/2, 2018 at 18:6 Comment(9)
Thanks @DougStevenson! I'm refactoring my Firestore project accordingly to prepare for prod. Any plans in the road map for multiple Firestore dbs in one project similar to Firebase?Moresque
@Moresque Realtime Database allows you to add multiple databases because there are limits to its scalability, and you need to shard your data across multiple DBs when you reach those limits. Firestore doesn't have those limitations, so there's no need for multiple DBs. You'll have to create different projects for each instance, if that's what you really need.Cymry
Thanks Doug. Is it legit to use two Cloud Firestore projects for one app ?Casaleggio
@Casaleggio Sure, there's nothing stopping you from doing that, if that's what you really need to do.Cymry
Two projects means two google-services.json files. How do I handle that ?Casaleggio
@Casaleggio It doesn't mean that at all. Do a search for "firebase multiple projects in one app" for some walkthroughs on how it can be done. You will have to write some init code. Auth may be kind of a pain.Cymry
why is Multitenancy not better supported? or at least documented. I'm looking for a solution using angularfire but I just can't find an answerFredericksburg
@Fredericksburg If you have questions about why something is the way it is for Firebase products, you should post to the Firebase discussion group. groups.google.com/forum/#!forum/firebase-talkCymry
Would you take the same approach with a database per service for microservices?Vd
F
27

Yes Firebase doesn't support multiple instance in a single project. However my case, i created 3 different document in Firestore root and setup each environment to refer these documents accordingly. Each document will have the same collections, sub collections and documents.

For example,

dev -> users -> details
    -> others_collection -> details

stag -> users
     -> others_collection -> details

prod -> users
     -> others_collection -> details

On the client side, each environment will get the collection like this :

db.collection(`${env}/users`)

I am doing this on small project and seem pretty happy with what Firestore provided. In single project. i can create many ios/android apps according to the environment and each environment have it own document and collections in Firestore.

Feltie answered 25/7, 2018 at 2:35 Comment(6)
This is convenient from a development perspective, but it seems less than ideal from a security standpoint. Any client from any of your environments can now access all the data from any of your other environments!Augsburg
Understood your concern. I think the rules help to increase the security and prevent users to access other env.Feltie
Any other drawbacks related to this approach?Pretended
Where do I store the env variable? Does Firebase automatically detect this?Aircool
How do you prevent yourself from writing data to the wrong env? I can just imagine when you forget and do a write to the db by accidentPurview
This will not easily work with firestore functions unless you copy your function code so you have differently named functions for each environment, which I would not recommend. Separate projects seems much safer.Ulaulah
J
11

The safest way is to create a new google cloud project. You can export your current firestore database to your new project if needed.

Step by step:

  1. Backup your current database by exporting all your documents into a bucket: https://firebase.google.com/docs/firestore/manage-data/export-import

    gcloud beta firestore export gs://[BUCKET_NAME]

  2. Create a new project -> https://cloud.google.com/resource-manager/docs/creating-managing-projects

  3. In the dashboard, select Firestore into your new project and create an empty database
  4. In the dashboard, go to your BACKUP_BUCKET and add your new project service account in the permission tab

  5. Switch project to your new project gcloud config set project 'new-project'

  6. Then export your data gcloud beta firestore import gs://[BUCKET_NAME]/[EXPORT_PREFIX]/ The EXPORT_PREFIX being the name of the folder created in your bucket.

I use this method to have clearly separated 'preprod' and 'production' environments (the team can access and synchronize with production without having access to the production environment codebase and configuration).

Juliannajulianne answered 6/3, 2019 at 16:12 Comment(2)
Export/import requires billing enabled. Which doesn't make sense for staging environmentSean
Depends of the size of your company I guess. Actually I don't understand your point, why billing shall be disabled in staging?Juliannajulianne
L
5

Nowadays, Firebase supports the use of multiple Firestore instances in a single project. Here is the announcement:

And here are the docs:

Lotte answered 2/8, 2023 at 11:0 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.