参考:

http://my.oschina.net/xiaomaoandhong/blog/63471,<<mongoDB权威指南>>

1.停掉服务器 然后备份

Mongodb将所有数据都存放在"数据目录(data/db)"下,启动mongoDB时可以用--dbpath指定我们自己设置的数据存储目录

备份: 只需要创建数据存储目录的副本就可以了,直接copy一份。

恢复: 在MongoDB启动时用 --dbpath指定数据存储目录副本的位置。

2.不停服务器 直接备份

1.mongodump和mongorestore

mongodump就是一种能在运行时备份的方法,mongoDB自带这个工具.

mongodump对运行的MongoDB做查询,然后将所有查询到的文档写入磁盘

mongostore是能获取mongodump的输出结果,并将备份的数据插入到运行的MongoDB实例中.mongodb也提供了这个工具

使用示例:

备份:mongodump -h dbhost -d test -o backup (或者 -o D:\test\dump\UserData)

其中:

-h 指定了Mongodb所在服务器的地址 如:127.0.0.1 或者 127.0.1.1:27017

-d 指定了要备份的数据库

-o 指定了备份的位置 此处表示 备份test数据库到与当前mongodump命令同一位置backup目录下

恢复:mongorestore -h dbhost -d foo --drop backup/test   (或者 --drop D:\test\dump\UserData)
其中:
-h Mongodb所在服务器地址
-d 指定了要恢复的数据库,可以将备份的数据库恢复到与原来不同的数据库中,这里为foo
-drop 表示在恢复前删除集合(若存在).否则,数据就出现与现有集合数据合并,可能会覆盖一些文档.
-- backup/test 是指备份文件的路径

优势:不用停掉服务器

不足之处:不是实时的快照;

在备份过程中会执行查询,对其他的业务查询会有性能上的影响

2.fsync和锁

原理:

fsync命令会强制服务器将所有缓冲区写入磁盘,还可以选择上锁阻止对数据库的进一步写入,以保证数据

的实时性。直到释放锁为止。

使用:

use admin

db.runCommand({fsync:1,lock:1});

//至此,数据目录的数据就是一致的,且为数据的实时快照。因为上了写入锁,可以保证安全的将数据目录副本用作备份。

db.$cmd.sys.unlock.findOne();

db.currentOp();

//运行db.currentOp(); 是为了确保已经解锁了.

优势:不用停掉服务器

是数据库的时候快照

不足之处:因为备份过程对数据库上了锁,所以会阻塞写入操作。

4、从属备份

当以复制的方式运行MongoDB时,前面提到的备份技术就不仅能用在主服务器上,也可以用在从服务器上;

从服务器的数据几乎和主服务器同步;

在从服务器上备份是MongoDB推荐的备份方式

导入导出参考:

http://chenzhou123520.iteye.com/blog/1641319

导出

Mongodb中的mongoexport工具可以把一个collection导出成JSON格式或CSV格式的文件。

mongoexport -h 119.147.53.178 --port 27777 -d UserData -c huodong_zmop_Record  --type=json -o lihao.json

可以通过参数指定导出的数据项,也可以根据指定的条件导出数据

导入

使用mongoimport工具可以把一个csv或者json等之类的文件导入指定集合

例子:导入一个包含有列名的csv文件
mongoimport -h 192.168.1.87:27017 -d "UserData" -c "huodong_4gzzhk" --type=csv --headerline --file=测试.csv

MongoDB系列----备份与导入导出的更多相关文章

  1. CRL快速开发框架系列教程九(导入/导出数据)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  2. Linux下mongodb安装及数据导入导出教程

    Linux下mongodb安装及数据导入导出教程 #查看linux发行版本 cat /etc/issue #查看linux内核版本号 uname -r 一.Linux下mongodb安装的一般步骤 1 ...

  3. mongodb 的备份恢复导入与导出

    导入导出 use hndb; db.s.save({name:'李四',age:18,score:80,address:'郑州'}); db.s.save({name:'李三',age:8,score ...

  4. mongdb 备份还原导入导出

    -------------------MongoDB数据导入与导出------------------- 1.导出工具:mongoexport     1.概念:         mongoDB中的m ...

  5. node.js零基础详细教程(6):mongodb数据库操作 以及导入导出

    第六章 建议学习时间4小时  课程共10章 学习方式:详细阅读,并手动实现相关代码 学习目标:此教程将教会大家 安装Node.搭建服务器.express.mysql.mongodb.编写后台业务逻辑. ...

  6. consul备份还原导入导出

    工作中要保证生产环境部署的consul的集群能够安全稳定地对外提供服务,即使出现系统故障也能快速恢复,这里将讲述部分的备份还原操作及KV的导入导出操作. 备份与还原 需要备份的主要有两类数据:cons ...

  7. 云服务器 ECS Linux 系统 MySQL 备份的导入导出

    MySQL 备份的导出 注意: 如果您使用的是帮助中心的一键环境配置,那么 MySQL 的安装目录是 /alidata/server/mysql. 如果您将 MySQL 安装到其他目录,您需要输入您 ...

  8. vertica系列:数据的导入导出

    本文仅涉及 Vertica 导入导出本地文件, 以及两个 Vertica 集群相互导出, 不涉及 Vertica 和 hdfs/Hive 导入导出和互操作. copy 数据导入工具 copy 命令无疑 ...

  9. elasticsearch 5.x 系列之五 数据导入导出

    一.首先给大家发一个福利,分享一个elasticsearch 数据导出工具. esm github 源码地址: https://github.com/medcl/esm 下载编译好的对应elastic ...

随机推荐

  1. Notes for "Python in a Nutshell"

    Introduction to Python Wrap C/C++ libraries into Python via Cython and CFFI. Python implementations ...

  2. CSS3标准盒模型还是IE怪异模型box-sizing属性的应用设置

    在一个文档中,每个元素都被表示为一个矩形的盒子.盒子模型具有4个属性['外边距(margin)','边框(border)','内边距(padding)','内容(content)']. 我们要设置某个 ...

  3. windows server 简化设置

    win2012任务管理器显示磁盘管理员运行命令提示符,diskperf -y 不要开机密码 运行 netplwiz 勾去掉 运行 gpedit.msc 计算机设置-Windows设置 -安全设置-帐户 ...

  4. PSO:利用PSO+ω参数实现对一元函数y = sin(10*pi*x) ./ x进行求解优化,找到最优个体适应度—Jason niu

    x = 1:0.01:2; y = sin(10*pi*x) ./ x; figure plot(x, y) title('绘制目标函数曲线图—Jason niu'); hold on c1 = 1. ...

  5. Nginx模块 ngx_http_limit_req_module 限制请求速率

    The ngx_http_limit_req_module module (0.7.21) is used to limit the request processing rate per a def ...

  6. Java 常用知识点

    Java 常用知识点 1.日期格式化 SimpleDateFormat Date date=new Date(System.currentTimeMillis()) ; SimpleDateForma ...

  7. (Android UI)Android应用程序中资源:图片、字符串、颜色、布局等

    Android系统设计采用代码和布局分离的设计模式,因此在设计Android应用程序时需要遵循该设计模式. “把非代码资源(如图片和字符串常量)和代码分离开来始终是一种很好的做法.”---<An ...

  8. Linux中Hadoop的环境搭建

    一:下载安装 Hadoop 1.1:下载指定的Hadoop 1.2:通过XFTP把文件上传到master电脑bigData目录下 1.3:解压hadoop压缩文件 tar -xvf hadoop-2. ...

  9. Petrozavodsk Summer-2017. Moscow IPT Contest

    A. A Place For My Head 留坑. B. New Divide 从高位到低位贪心,当这一位是$0$时,要尽量取$1$,维护高维后缀最小值进行判断即可. 时间复杂度$O((n+a)\l ...

  10. ZOJ Monthly, March 2018

    A. Easy Number Game 贪心将第$i$小的和第$2m-i+1$小的配对即可. #include<cstdio> #include<algorithm> usin ...