MongoDB使用自带的命令行工具进行备份和恢复的教程


本文整理自网络,侵删。

要备份一个数据库,

mongorestore -d db /path/to/back_up

例如:

mongodump -d bookstore -o /data01/db_backup/

该命令会dump出该DB所有的collection
从备份文件夹恢复数据

mongorestore -d bookstore /data01/db_backup/bookstore

只备份或回复指定的collection
以bookstore DB 中statistics 表为例

mongodump -d bookstore -c statistics -o /data01/db_backup/

然后restore时指定该collection对应的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中有$符号,需要转义,例如

mongodump -d qunimei -c collection_name -q "{\"date\": {\"\$gte\": \"2015-03-25\"}}" -o /path/to/dump

注意事项
mongorestore并不会覆盖已有的记录,而是重复添加(如果可以的话)。
当数据量很大的时候,该方法耗时很大。
直接备份数据文件

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()"

关键是第一行和第三行的两个命令,对于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 未完成的写操作写入数据文件并阻止新的写入操作,知道运行db.fsyncUnlock()命令,因此拷贝数据文件前后要执行这两个命令。

阅读剩余部分

相关阅读 >>

mongodb实现查询、分页和排序操作以及游标的使用

mongodb最基本命令速查笔记

mongodb系列教程(一):nosql起源

mongodb数据库条件查询技巧总结

mongodb副本集和分片示例详解

mongodb中的参数限制与阀值详析

详解mongodb中的日志模块

windows系统下安装mongodb与robomongo环境详解

mongodb系列教程(八):gridfs存储详解

mongodb导入json数据的方法

更多相关阅读请进入《mongodb》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...

    正在狠努力加载,请稍候...