MongoDB备份和还原的操作指南

 更新时间:2024年05月20日 10:01:12   作者:*老工具人了*  
MongoDB备份和还原是指将MongoDB数据库中的数据和集合备份到另一个存储位置,并在需要的时候恢复这些备份的过程,备份和还原MongoDB数据库非常重要,本文给大家介绍了MongoDB备份和还原的操作指南,需要的朋友可以参考下

MongoDB 提供的命令行实用程序mongodumpmongorestore创建备份和恢复数据的过程。

一、数据备份

mongorestoremongodump实用程序可处理BSON数据转储,对于创建小型部署的备份非常有用。要实现弹性且无中断的备份,请将文件系统快照或区块级磁盘快照与 MongoDB Atlas 的云备份结合使用。

性能影响

由于mongodump和mongorestore是通过与正在运行的mongod实例交互来进行操作的,因此它们可能会影响正在运行的数据库的性能。这些工具不仅会为正在运行的数据库实例创建流量,还会强制数据库通过内存读取所有数据。当 MongoDB 读取不常使用的数据时,它可能会逐出更频繁访问的数据,从而导致数据库常规工作负载的性能下降。

排除 local 数据库

mongodump会在其输出中排除local数据库的内容。

local数据库:用于存储诊断信息、复制集配置和操作日志等数据,其中的集合不会被复制

基本 mongodump 操作

mongodump`实用程序通过连接到正在运行的`mongod来备份数据。

该工具可以为整个服务器、数据库或集合创建备份,也可以结合查询来仅备份一个集合的某一部分。

备份命令

export local_tar_dir="/opt/mongodb/upload_backup/"
export dump_name="backup-mongo{{ now_date |replace('-', '')}}"#显示日期
mongodump \
-h {{ ansible_default_ipv4.address }} \
-u{{ mongo_user }} -p{{ mongo_password }} \
--authenticationDatabase admin \
-o {{ local_tar_dir }}/{{ dump_name }} \
--gzip
#-o: 指定输出目录

#打成压缩包后进行上传到对象存储

备份命令其他参数

要限制数据库转储中包含的数据量,可以指定--db--collection作为mongodump的选项。例如:

mongodump --collection=myCollection --db=test

二、集群还原

适用于整个集群不可用或者误删除了部分数据无法找回的情况

下载备份到指定目录

#obs华为云
sudo /usr/local/bin/obsutil ls obs://jws2-live-cn-backup-01/db-db-mongodb/2024-03-28/05/ -s | grep "_master"
sudo /usr/local/bin/obsutil cp {{ first_tarball }} /tmp/

#gcp谷歌云
/bin/gsutil ls gs://{{cloud_backup_bucket}}/db-mongodb/{{now_date}}/{{now_hour}}/
/bin/gsutil  cp  {{ backup_file.stdout }}   /tmp/

基本 mongorestore 操作

mongorestore实用程序可恢复mongodump创建的二进制备份。默认情况下, mongorestore会在dump/目录中查找数据库备份。

mongorestore实用程序通过直接连接到正在运行的mongod来恢复数据。

mongorestore 可以恢复整个数据库备份或部分的备份。

可以考虑使用mongorestore --drop选项从数据库中删除每个集合,然后再从备份恢复。

如果恢复到强制执行访问控制的实例,请同时包括--username和--authenticationDatabase 。

还原前准备

需要保证副本集正常运行,所有游戏服都停止,不会有客户端对mongodb进行写操作。

登录mongodb副本集

#登录mongodb副本集
mongo mongodb://root:mgwh7B8H9w5dc8j0@10.156.0.4:27017,10.156.0.5:27017,10.156.0.6:27017,/admin?replicaSet=jws2-test

查找主节点

rs.status()
#副本集配置成功后,172.16.60.205为主节点PRIMARY,172.16.60.206/207为副本节点SECONDARY。
health:1   1表明状态是正常,0表明异常
state:1     值小的是primary节点、值大的是secondary节点
#"stateStr" : "PRIMARY",        (代表为主节点)

还原命令

副本集还原和单节点命令相同,需要注意一点,要保证-h参数指定的主机为副本集的主节点

以下为对单个库进行还原,可以按照自己的需求进行还原操作。

mongorestore \
-h 172.16.185.222:27011 \
-p mgwh7B8H9w5dc8j0 -u root1 \
--authenticationDatabase=admin  \
--db=SilenceDB  --drop --gzip \
/home/jms_ops_all/backup-mongo20240507/SilenceDB/

三、单节点还原

适用于单机点不可用,但是集群可用的情况。

向副本集添加成员

MongoDB 提供了两个用于恢复副本集从节点成员的选项:

  • 手动将数据库文件复制到每个数据目录。
  • 允许初始同步以自动分发数据。

具体步骤

停止数据异常的成员节点

sudo supervisorctl stop mongodb

清理数据异常的成员节点的数据目录

mv ./mongodata ./mongodata_bak
mkdir ./mongodata

情况一:数据量不大,直接启动即可,初始同步会将数据从主成员复制到新成员。

sudo supervisorctl start mongodb

情况二:数据量大,

将主成员的数据目录复制到新的辅助成员,再启动即可。

以上就是MongoDB备份和还原的操作指南的详细内容,更多关于MongoDB备份还原的资料请关注脚本之家其它相关文章!

相关文章

  • MongoDB聚合运算符$divide详解

    MongoDB聚合运算符$divide详解

    $divide聚合运算符返回两个表达式相除的结果,参数通过数组传递给$divide运算符,这篇文章介绍了MongoDB聚合运算符$divide的相关知识,感兴趣的朋友跟随小编一起看看吧
    2024-03-03
  • MongoDB最大连接数设置失效的异常分析过程与解决方法

    MongoDB最大连接数设置失效的异常分析过程与解决方法

    mongodb最大连接数是20000。所以业界流传一段话,千万级以下的用mysql、千万级以上的用mongodb,亿级以上的用hadoop。下面这篇文章主要给大家介绍了关于MongoDB最大连接数设置失效的异常分析过程,需要的朋友可以参考下
    2018-09-09
  • mongodb处理中文索引与查找字符串详解

    mongodb处理中文索引与查找字符串详解

    这篇文章主要介绍了mongodb处理中文索引与查找字符串的相关资料,文中介绍的非常详细,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • 解决mongodb在ubuntu下启动失败,提示couldn‘t remove fs lock errno:9 Bad file descriptor的错误

    解决mongodb在ubuntu下启动失败,提示couldn‘t remove fs lock errno:9 Bad

    之前MongoDB启动的时候是蛮正常的,不知道后来启动报错了,就把粘贴出来查询了。经过一番百度,才找的处理的办法,分享给大家
    2014-08-08
  • mongoDB4.0数据库的操作方法

    mongoDB4.0数据库的操作方法

    这篇文章主要介绍了mongoDB4.0数据库的操作方法及注意事项,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10
  • mongodb 数据块的迁移流程分析

    mongodb 数据块的迁移流程分析

    这篇文章主要介绍了mongodb 数据块的迁移流程介绍,包括数据块迁移对集群性能的影响,建议设置平衡器的活跃时间窗口,设置为业务低估时进行,具体操作步骤文中有介绍,需要的朋友可以参考下
    2022-04-04
  • MongoDB基础命令以及操作示例详解

    MongoDB基础命令以及操作示例详解

    Mongodb:是一种NoSQL数据库,下面这篇文章主要给大家介绍了关于MongoDB基础命令以及操作的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-08-08
  • Mongodb 如何将时间戳转换为年月日日期

    Mongodb 如何将时间戳转换为年月日日期

    这篇文章主要介绍了Mongodb 如何将时间戳转换为年月日日期,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • mongodb 查看数据库和表大小

    mongodb 查看数据库和表大小

    mongodb查看数据库和表的方法比较简单,在为这里推荐使用stats的方法,直观并且详细。
    2014-07-07
  • 浅析MongoDB用户管理

    浅析MongoDB用户管理

    mongodb在2.4最新版本中对用户权限管理做了全新的调整,把权限细化了,增强了安全性,越来越像mysql的权限管理了。废话少说,我们来详细看下吧
    2014-08-08

最新评论