MongoDB使用自帶的命令行工具進行備份和恢復(fù)的教程
要備份一個數(shù)據(jù)庫,
mongorestore -d db /path/to/back_up
例如:
mongodump -d bookstore -o /data01/db_backup/
該命令會dump出該DB所有的collection
從備份文件夾恢復(fù)數(shù)據(jù)
mongorestore -d bookstore /data01/db_backup/bookstore
只備份或回復(fù)指定的collection
以bookstore DB 中statistics 表為例
mongodump -d bookstore -c statistics -o /data01/db_backup/
然后restore時指定該collection對應(yīng)的bson文件
mongorestore -d bookstore -c statistics /data01/db_backup/bookstore/statistics.bson
通過條件查詢dump
還可以通過一個query來dump中一個collection中符合條件的某些記錄, 例如
mongodump -d bookstore -c novel_sources -q "{\"tag\": \"tag_11\"}" -o /data01/db_backup/
要注意的是如果query中有$符號,需要轉(zhuǎn)義,例如
mongodump -d qunimei -c collection_name -q "{\"date\": {\"\$gte\": \"2015-03-25\"}}" -o /path/to/dump
注意事項
mongorestore并不會覆蓋已有的記錄,而是重復(fù)添加(如果可以的話)。
當數(shù)據(jù)量很大的時候,該方法耗時很大。
直接備份數(shù)據(jù)文件
mongo 127.0.0.1:27017/db_to_back --eval "db.fsyncLock()" rsync -avh --delete /path/to/your/mongofile /path/to/backup/folder/ mongo 127.0.0.1:21001/turbo --eval "db.fsyncUnlock()"
關(guān)鍵是第一行和第三行的兩個命令,對于db.fsyncLock(),mongodb的文檔說明
db.fsyncLock()
Forces the mongod to flush all pending write operations to the disk and locks the entire mongod instance to prevent additional writes until the user releases the lock with the db.fsyncUnlock() command. db.fsyncLock() is an administrative command.將mongod 未完成的寫操作寫入數(shù)據(jù)文件并阻止新的寫入操作,知道運行db.fsyncUnlock()命令,因此拷貝數(shù)據(jù)文件前后要執(zhí)行這兩個命令。
與其他備份恢復(fù)工具的對比
mongodb自帶的備份工具還有bsondump、mongoexport,恢復(fù)工具還有mongoimport ,幾者之間的具體區(qū)別是:
bsondump、mongoexport、mongodump備份工具的對比:
1、bsondump可以指定備份的格式為json和debug模式,這個命令雖然附帶,但很少用到 ;
2、mongoexport 可以導(dǎo)出json或csv格式的文件,可以指定查詢過濾器或指定輸出的域,不過此工具導(dǎo)出的json,csv可能對某些數(shù)據(jù)類型不兼容,因此可能不能全部數(shù)據(jù)導(dǎo)出,mongodump就可以全部兼容 ;
3、mongodump支持過濾 ,而且在導(dǎo)出速度和壓縮率方面mongodump是最快最好的 。所以,若無csv或debug等特殊格式的備份需求,一般都使用 mongodump 作為備份工具 。
mongorestore與mongoimport 恢復(fù)工具的對比:
1、 mongoimport 可以接受json,csv,tsv格式的文件,每行為一個對象 。同mongoexport一樣,其在恢復(fù)過程中同樣存在兼容性的問題,所以有恢復(fù)不完整的概率 ;
2、mongorestore,速度較慢,比mongoimport慢2.5倍左右,但是根據(jù)mongodump導(dǎo)出的數(shù)據(jù),可以完整導(dǎo)入數(shù)據(jù)。在restore過程中,索引根據(jù)之前dump的結(jié)果重新創(chuàng)造。
- MongoDB的備份與恢復(fù)
- mongoDB4.2.8備份恢復(fù)與導(dǎo)出導(dǎo)入(推薦)
- 分布式文檔存儲數(shù)據(jù)庫之MongoDB備份與恢復(fù)的實踐詳解
- 使用centos系統(tǒng)中的crontab命令對mongodb定時備份恢復(fù)
- Mongodb實現(xiàn)定時備份與恢復(fù)的方法教程
- MongoDB 導(dǎo)出導(dǎo)入備份恢復(fù)數(shù)據(jù)詳解及實例
- Windows或Linux系統(tǒng)中備份和恢復(fù)MongoDB數(shù)據(jù)的教程
- Mongodb數(shù)據(jù)庫的備份與恢復(fù)操作實例
- MongoDB整庫備份與還原以及單個collection備份、恢復(fù)方法
- MongoDB的備份(mongodump)與恢復(fù)(mongorestore)
相關(guān)文章
教大家8天學(xué)通MongoDB——第一天 基礎(chǔ)入門篇
MongoDB是目前非常流行的一種非關(guān)系型數(shù)據(jù)庫(NoSQL),因其操作簡單、完全免費、源碼公開等特點,受到了IT從業(yè)人員的青睞,并被廣泛部署于實際的生產(chǎn)環(huán)境中。本文教大家8天學(xué)通MongoDB——第一天 基礎(chǔ)入門篇,感興趣的朋友一起來了解了解吧2015-09-09
MongoDB學(xué)習(xí)之Text Search文本搜索功能
這篇文章主要給大家介紹了MongoDB之Text Search文本搜索功能的相關(guān)資料,文中給出了詳細的示例代碼供大家參考學(xué)習(xí),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-05-05
Pycharm連接MongoDB數(shù)據(jù)庫安裝教程詳解
這篇文章主要介紹了Pycharm連接MongoDB數(shù)據(jù)庫安裝教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11
Win10 64位安裝MongoDB數(shù)據(jù)庫的詳細教程
這篇文章主要介紹了Win10 64位安裝MongoDB數(shù)據(jù)庫的詳細教程,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12
JavaScript按日期查詢MongoDB中的數(shù)據(jù)的要點示例
這篇文章主要介紹了JavaScript按日期查詢MongoDB中數(shù)據(jù)的要點示例,MongoDB所支持的BSON有JSON沒有的一些數(shù)據(jù)類型,如Date和BinData類型,需要的朋友可以參考下2016-03-03
關(guān)于CentOS 8 搭建MongoDB4.4分片集群的問題
在MongoDB里面存在另一種集群,就是分片技術(shù),可以滿足MongoDB數(shù)據(jù)量大量增長的需求。這篇文章主要介紹了CentOS 8 搭建MongoDB4.4分片集群的問題,需要的朋友可以參考下2021-10-10
Mongodb 崩潰報錯 Too many open files的問題解析
這篇文章主要介紹了Mongodb 崩潰報錯 Too many open files的問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12
基于MongoDB數(shù)據(jù)庫索引構(gòu)建情況全面分析
下面小編就為大家?guī)硪黄贛ongoDB數(shù)據(jù)庫索引構(gòu)建情況全面分析。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
分布式文檔存儲數(shù)據(jù)庫之MongoDB分片集群的問題
這篇文章主要介紹了分布式文檔存儲數(shù)據(jù)庫之MongoDB分片集群的問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11

