使用mongodump和mongorestore备份与恢复Mongodb数据
mongodump仅备份数据库中的文档,不备份索引,所以我们还原后,需要重新生成索引。说明:当前环境的mongodb服务是采用容器部署的,这里的/data/backup是指容器中的备份目录,备份文件会存放在这个目录下,你也可以将容器中的/data/backup目录映射为当前宿主机上的某一目录。mongodump是MongoDB官方提供的备份工具,它可以从MongoDB数据库读取数据,并生成BSON
·
一、备份与恢复方案
mongodump是MongoDB官方提供的备份工具,它可以从MongoDB数据库读取数据,并生成BSON文件,mongodump适合用于备份和恢复数据量较小的MongoDB数据库, 不适用于大数据量备份。
默认情况下mongodump不获取local数据库里面的内容。mongodump仅备份数据库中的文档,不备份索引,所以我们还原后,需要重新生成索引。 mongodump备份过程中会对mongod服务的性能产生影响,我们建议在业务低峰期进行操作。如果我们备份的数据,大于系统内存,我们备份的时候容易出现错误。
查阅:Mongodb原生导入导出工具对比
二、备份与恢复参数
2.1、mongodump参数详解
说明:这里主要介绍mongodump常用参数。
2.2、mongorestore参数详解
说明:这里主要介绍mongorestore常用参数。
三、备份与恢复操作
3.1、环境信息
主机IP | 操作系统 | 软件版本 |
---|---|---|
192.168.1.191 | Centos7.6 | Mongodb3.2.22 |
3.2、备份操作
说明:当前环境的mongodb服务是采用容器部署的,这里的/data/backup是指容器中的备份目录,备份文件会存放在这个目录下,你也可以将容器中的/data/backup目录映射为当前宿主机上的某一目录。
1、备份全库,图片这步操作是进入容器备份
[root@localhost ~]# docker exec mongo-single bash -c 'mongodump --host 127.0.0.1:27017 -ulolaage -p123456 -d possecu -o /data/backup --gzip'
2、备份某集合
[root@localhost ~]# docker exec mongo-single bash -c 'mongodump --host 127.0.0.1:27017 -ulolaage -p123456 -d possecu -o /data/backup -c PersonLogin --gzip'
说明:
--host:指定ip和端口
-u:用户
-p:密码
-c: 指定集合名称
-d:指定备份的库名
-o: 备份输出到哪个目录
--gzip:从压缩文件中进行恢复
--drop:恢复数据之前删除原来数据库数据,避免数据重复
如下图所示:
3.2、恢复操作
1、恢复全库先删除数据在导入–drop谨慎操作,图片这步操作是把备份放入容器进入容器导入
首先得创建数据库name,并授权才可以导入
use name
db.createUser(
{
user:"lijia",
pwd:"123456",
roles:[{role:"readWrite",db:"name"}]
}
);
[root@localhost ~]# docker exec mongo-single bash -c 'mongorestore --host 127.0.0.1:27017 -ulolaage -p123456 -d possecu --dir /data/backup/possecu --gzip --drop '
2、恢复某集合(注意恢复的时候必须要有这个用户和数据库)
[root@localhost mongo]# docker exec mongo-single bash -c 'mongorestore --host 127.0.0.1:27017 -ulolaage -p123456 -d possecu -c PersonLogin /data/backup/possecu/PersonLogin.bson.gz --gzip --drop '
说明:
--host:指定ip和端口
-u:用户
-p:密码
-d:指定恢复的库名
--dir: 指定恢复目录
--gzip:压缩备份文件
如下图所示
检查
更多推荐
已为社区贡献5条内容
所有评论(0)