参考:

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. Exceptionless 生产部署笔记

    参考 部署用于生产的Exceptionlees(一个强大易用的日志收集服务) 1. 安装配置 redis 4.0  点击下载redis教学脑图 cd /opt wget http://download ...

  2. web存储中cookie、session区别

    http协议是一种无状态的协议,浏览器对服务器的每一次请求都是独立的.为了使得web能够产生一些动态信息,就需要保存”状态”,而cookie和session机制就是为了解决http协议无状态而产生.c ...

  3. Eclipse4.8.0的svn插件离线安装说明

    Eclipse4.8.0离线安装Subclipse(SVN插件)的方法: Subclipse迁到github上了,地址:https://github.com/subclipse/subclipse/w ...

  4. 反素数ant HYSBZ - 1053(数学+dfs)

    对于任何正整数x,其约数的个数记作g(x).例如g(1)=1.g(6)=4.如果某个正整数x满足:g(x)>g(i) 0<i<x ,则称x为反质数.例如,整数1,2,4,6等都是反质 ...

  5. CF 960 G

    难受的1b,怎么会这样 先去学写一发 NTT 大概说一下斯特林数

  6. (转)InFluxDB数据库使用手册

    InfluxDB是一个开源的时序数据库,使用GO语言开发,特别适合用于处理和分析资源监控数据这种时序相关数据.而InfluxDB自带的各种特殊函数如求标准差,随机取样数据,统计数据变化比等,使数据统计 ...

  7. Anaconda基础(一)

    目录 Conda常见命令 环境管理 包管理 conda管理 小技巧 Conda常见命令 环境管理 创建环境 conda create -n 环境名 包列表 进入环境 source activate 环 ...

  8. vue中,对象数组多层嵌套时,更新数据更新页面

    vue中的对象和数组的元素直接赋值修改时,是不能响应到view中去的 1.对象更新 this.a={title:'列表1’}; this.a.title='列表2’; <h1>{{a.ti ...

  9. 新浪实时股票数据接口http://hq.sinajs.cn/list=股票代码

    股票数据的获取目前有如下两种方法可以获取: 1. http/JavaScript接口取数据 2. web-service接口 1.http/JavaScript接口取数据1.1Sina股票数据接口以大 ...

  10. [LeetCode] Shortest Distance to a Character 到字符的最短距离

    Given a string S and a character C, return an array of integers representing the shortest distance f ...