MongoDB 备份(mongodump)与恢复(mongorestore)

MongoDB数据备份

在Mongodb中我们使用mongodump命令来备份MongoDB数据。该命令可以导出所有数据到指定目录中。 mongodump命令可以通过参数指定导出的数据量级转存的服务器。

语法

mongodump命令脚本语法如下:

>mongodump -h dbhost -d dbname -o dbdirectory
  • -h: MongDB所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:27017
  • -d: 需要备份的数据库实例,例如:test
  • -o: 备份的数据存放位置,例如:c:\data\dump,当然该目录需要提前建立,在备份完成后,系统自动在dump目录下建立一个test目录,这个目录里面存放该数据库实例的备份数据。

实例

在本地使用 27017 启动你的mongod服务。打开命令提示符窗口,进入MongoDB安装目录的bin目录输入命令mongodump:

>mongodump

执行以上命令后,客户端会连接到ip为 127.0.0.1 端口号为 27017 的MongoDB服务上,并备份所有数据到 bin/dump/ 目录中。命令输出结果如下: 结果

MongoDB数据备份

mongodump 命令可选参数列表如下所示:

| 语法 | 描述 | 实例 | | :-------------------------------------------- |:--------------------------------|: ------------------------------------------------------| |mongodump --host HOST_NAME --port PORT_NUMBER|该命令将备份所有MongoDB数据|mongodump --host w3cschool.cc --port 27017| |mongodump --dbpath DB_PATH --out BACKUP_DIRECTORY| |mongodump --dbpath /data/db/ --out /data/backup/| |mongodump --collection COLLECTION --db DB_NAME|该命令将备份指定数据库的集合|mongodump --collection mycol --db test|

MongoDB数据恢复

mongodb使用 mongorestore 命令来恢复备份的数据。

语法

mongorestore命令脚本语法如下:

>mongorestore -h <hostname><:port> -d dbname <path>
  • --host <:port>, -h <:port>: MongoDB所在服务器地址,默认为: localhost:27017
  • --db , -d : 需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如test2
  • --drop: 恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,慎用哦!
  • <path>: mongorestore 最后的一个参数,设置备份数据所在位置,例如:c:\data\dump\test。 你不能同时指定 <path> 和 --dir 选项,--dir也可以设置备份目录。
  • --dir: 指定备份的目录 你不能同时指定 <path> 和 --dir 选项。

接下来我们执行以下命令: >mongorestore 执行以上命令输出结果如下: MongoDB数据恢复 结果

一:问题描述

备份时,报错:

[root@ser6-51 ~]# mongodump  -d myTest -o /backup/MongoDB/all_bak_20150619.bak -u=superuser -p=123456

2015-06-29T10:17:10.784+0800 Failed: error connecting to db server: server returned error on SASL authentication step: Authentication failed.

二:解决办法

添加--authenticationDatabase admin

如:

[root@ser6-51 mongodb]# mongodump  -d myTest -o /backup/mongodb/all_bak_20150619.bak -u superuser -p=123456 --authenticationDatabase admin

2015-06-29T10:24:21.427+0800 writing myTest.system.indexes to /backup/mongodb/all_bak_20150619.bak/myTest/system.indexes.bson

2015-06-29T10:24:21.428+0800 writing myTest.t to /backup/mongodb/all_bak_20150619.bak/myTest/t.bson

2015-06-29T10:24:21.428+0800 writing myTest.t2 to /backup/mongodb/all_bak_20150619.bak/myTest/t2.bson

2015-06-29T10:24:21.429+0800 writing myTest.t metadata to /backup/mongodb/all_bak_20150619.bak/myTest/t.metadata.json

2015-06-29T10:24:21.429+0800 writing myTest.t2 metadata to /backup/mongodb/all_bak_20150619.bak/myTest/t2.metadata.json

2015-06-29T10:24:21.468+0800 done dumping myTest.t2

2015-06-29T10:24:21.468+0800 done dumping myTest.t

--注意:指定密码时,必须在-p后添加‘=密码’,否则也会报错:error parsing command line options: expected argument for flag `-p, --password'

转载于:https://my.oschina.net/xuqiang/blog/869786

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值