数据备份及恢复(mongodump/mongorestore)
数据备份及恢复(mongodump/mongorestore)
2019年01月17日 16:22:29 DreamLRH 阅读数 266
说明
1.mongodump创建高保真的BSON文件,mongorestore可以用其恢复数据库。对于小型数据库的备份和恢复,这两个工具非常简单和高效,但对于大型数据库的备份并不理想。 2.mongodump/mongorestore可以直接对正在运行的mongodb执行操作。 3.默认情况下,mongodump不会捕获本地数据库的内容,而只是捕获其中的document,所以占用空间较小(我试过了,占用空间也不少,原空间占用17G,备份完了37G)。不过,这也导致mongorestore恢复数据时,需要重建索引。 4.mongodump执行过程中会影响mongodb的性能。另外,即使执行结束后的一段时间性能依然会受到影响,因为读取冷数据时,会把热数据从缓存中挤出去了。 5.如果数据大于系统内存,那么查询将会导致内存溢出,从而导致page faults。不过我测试时,待备份数据17G,机器内存8G,并没有出现错误。 6.如果输出文件夹中有文件,mongodump会覆盖。
--oplog
mongodump使用--oplog选项,捕获备份过程中的修改,以保障备份数据的一致性。但这个需要另外配置,涉及复制功能。本文档未使用此选项。相对应的,如果备份时使用--oplog,那么恢复数据时使用--oplogReplay选项。
--host/--port
可以使用--host/--port指定要备份的实例。用这两个选项可以进行远程备份。
--db/--collection
指定备份的数据和集合。
--out
mongodump使用此选项,指定备份的数据写到哪个路径。如果不指定,默认写在当前工作目录的dump/路径下。
--objcheck
插入数据时,检查完整性。
--drop
在恢复数据之前,删除之前的集合。
操作步骤
1.执行备份命令,将备份数据写入到/home/dump/文件夹下。如下各命令使用的用户“root”是超级用户,其角色为内置角色root。
mongodump --username "root" --password "xxxxxx" --out /home/dump/
如果出现如下内容,则表示备份完成:
备份的数据包含288万多条document,数据库大小16G多,耗时14分钟左右。
2.执行恢复命令。
mongorestore --username "root" --password "xxxxxx" /home/dump/
如果出现如下内容,则表示恢复完成:
数据恢复总共耗时17分钟左右。其中数据恢复完成后,重建索引花费了5分钟的时间。
(adsbygoogle = window.adsbygoogle || []).push({});
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法