There is an easy way to migrate MongoDB database between different hosts. Sometimes we might need it for example in case of:
- moving db from local database to the remote
- creating a backup copy of the db "freezing" all the content we have to be able to restore at some time
- getting the production db and moving to local server for some testing, development, etc..
And any other possible case you might think about.
With mongodump it's only 2 simple steps.
First you will need to install mongodump for your platform: https://www.mongodb.com/docs/database-tools/mongodump/
Then first step is to create the dump:
mongodump --uri='URLOFMONGO'
'URLOFMONGO'
is URL you are using to connect your app to MongoDB -- either local like let's say mongodb://127.0.0.1/ourDatabase
or remote like mongodb+srv://yourSuperApp:superSecretPassword@cluster0.wxtxjy6.mongodb.net/superAppDB
data:image/s3,"s3://crabby-images/eda87/eda874dc2b3f8b461a85680573e6cdb98e7193d7" alt=""
It will save the dump – the whole content of your database – in the dump
folder in the current folder from there the command was executed.
Inside dump
folder you would see the folder with the name of the DB - it's the one you would like to use to restore.
data:image/s3,"s3://crabby-images/a0026/a0026682425ee07b5a7d19494502882efacaad68" alt=""
To restore:
mongorestore --uri='URL_OF_MONGODB' -d NAME_OF_DB_TO_PUT_DATA_INTO FOLDER_WITH_DUMP
such as
mongorestore --uri='mongodb://127.0.0.1' -d winemind dump/Winemind
data:image/s3,"s3://crabby-images/d02ae/d02ae14dad543493f2069370c5f640fb4e13c648" alt=""
Now we moved data from remote DB called Winemind
to localhost DB named winemind
The end :)