--備份單個表 mongodump -u superuser -p 123456 --port 27017 --authenticationDatabase admin -d myTest -c d -o /backup/mongodb/myTest_d_bak_201507021701.bak --備份單個庫 mongodump -u superuser -p 123456 --port 27017 --authenticationDatabase admin -d myTest -o /backup/mongodb/ --備份所有庫 mongodump -u superuser -p 123456 --authenticationDatabase admin --port 27017 -o /root/bak --備份所有庫推薦使用添加--oplog參數的命令,這樣的備份是基於某一時間點的快照,只能用於備份全部庫時才可用,單庫和單表不適用: mongodump -h 127.0.0.1 --port 27017 --oplog -o /root/bak --同時,恢復時也要加上--oplogReplay參數,具體命令如下(下面是恢復單庫的命令): mongorestore -d swrd --oplogReplay /home/mongo/swrdbak/swrd/ --恢復單個庫: mongorestore -u superuser -p 123456 --port 27017 --authenticationDatabase admin -d myTest /backup/mongodb/ --恢復所有庫: mongorestore -u superuser -p 123456 --port 27017 --authenticationDatabase admin /root/bak --恢復單表 mongorestore -u superuser -p 123456 --authenticationDatabase admin -d myTest -c d /backup/mongodb/myTest_d_bak_201507021701.bak/myTest/d.bson
注:
1、mongorestore恢復數據默認是追加,如打算先刪除后導入,可以加上--drop參數,不過添加--drop參數后,會將數據庫數據清空后再導入,如果數據庫備份后又新加入了數據,也會將新加的數據刪除,它不像mysql有一個存在的判斷。
2、mongodump在mongo關閉時,也是可以備份的,不過需要指定數據目錄,命令為:
mongodump --dbpath /data/db
3、在備節點使用mongodump備份時,必須加上--oplog參數,否則備份的狀態不會和任何其他集群成員的狀態相吻合,另外在恢復時還需創建一份oplog,用來恢復備份期間所做的操作。
恢復: 1、將復制集中要恢復的節點移除 rs.remove("10.10.17.26:27000") 2、運行mongorestore --oplogReplay命令 mongorestore --host 10.10.17.26 --port 27000 --oplogReplay /data/mongodbbackup/20150820/ 3、創建oplog use local db.createCollection("oplog.rs", {"capped" : true, "size" : 10000000}) 4、恢復oplog mongorestore --host 10.10.17.26 --port 27000 -d local -c oplog.rs /data/mongodbbackup/20150820/oplog.bson 5、將該節點加入到復制集 rs.add("10.10.17.26:27000")
4、mongodump與mongoexport的區別:
- mongodump導出的是bson格式,是二進制形式,不過可以使用mongo自帶的bsondump命令查看里面的數據,而mongoexport導出的則是文本,可以是csv、json格式。
- JSON可讀性強但體積較大,BSON則是二進制文件,體積小但對人類幾乎沒有可讀性。
- 在一些mongodb版本之間,BSON格式可能會隨版本不同而有所不同,所以不同版本之間用mongodump/mongorestore可能不會成功,具體要看版本之間的兼容性。當無法使用BSON進行跨版本的數據遷移的時候,使用JSON格式即mongoexport/mongoimport是一個可選項。跨版本的mongodump/mongorestore個人並不推薦,實在要做請先檢查文檔看兩個版本是否兼容(大部分時候是的)。
- JSON雖然具有較好的跨版本通用性,但其只保留了數據部分,不保留索引,賬戶等其他基礎信息。使用時應該注意。