一、备份与恢复方案

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.191Centos7.6Mongodb3.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:压缩备份文件

如下图所示
在这里插入图片描述

检查
在这里插入图片描述

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐