Mongodb 备份与还原

文件快照

利用Linux LVM 逻辑卷管理,制作快照后,将快照映像挂载到文件系统上并从快照复制数据。生成的备份包含所有数据的完整副本,从而达到备份数据库。

注意:Mongodb数据与日志目录需要启动在逻辑卷挂载到目录中

快照备份

db.fsyncLock();                                             # 锁定数据库

vgcreate vg01 /dev/sdb                                      # 创建卷组
lvcreate --size 1G --name mongodb_bak /dev/vg01 # 创建快照 umount /dev/vg01/mongodb_bak # 卸载
dd if=/dev/vg01/mongodb_bak | gzip > bak/20210817.gz # 压缩归档 db.fsyncUnlock(); # 解锁数据库

快照直接还原

db.fsyncLock();                                             # 锁定数据库

umount /dev/vg01/mongodb_01                                 # 卸载lv

lvcreate --size 1G --name mongodb_restore /dev/vg01         # 创建lv

mkfs.ext4 /dev/vg01/mongodb_restore                         # 格式化ext4,不然还原后挂载不了
dd if=/dev/vg01/mongodb_bak of=/dev/vg01/mongodb_restore # 复制文件到新快照 mount /dev/vg01/mongodb_new /mongodb # 挂载新的快照到数据目录 db.fsyncUnlock(); # 解锁数据库

从压缩文件还原

umount /dev/vg01/mongodb_bak                                # 卸载lv

lvcreate --size 1G --name mdb-new vg0                       # 创建lv

gzip -d -c 20210817.gz | dd of=/dev/vg0/mdb-new             # 解压并复制到新lv

mount /dev/vg01/mdb-new /mongodb                            # 挂载

优缺点

优点

  1. 快速
  2. 支持时间点的快照备份
  3. 提供增量备份

缺点

  1. 需要文件系统支持时间点快照(LVM)
  2. 需要开启日志功能
  3. 快照创建整个磁盘的镜像,因此将数据文件,配置,日志放在一个逻辑磁盘上节约空间

复制文件

备份文件

service mongod stop                                                                           # 停止mongod

echo `date +%Y%m%d%H%M%S` | xargs -I {} sh -c 'mkdir ./bak/{}; cp -a /mongodb/data ./bak/{}'  # 按日期格式归档

service mongod restart                                                                        # 重新启动mongodb

从文件还原

service mongod stop                                                                           # 停止mongod

echo bak_`date +%Y%m%d%H%M%S` | xargs -I {} sh -c 'mkdir ./bak/{};mv /mongodb/data ./bak/{}'  # 备份当前文件

cp -a bak/20210818025815/data /mongodb                                                        # 使用备份数据还原

service mongod restart                                                                        # 重新启动mongodb

优缺点

优点

  1. 无需文件系统支持快照功能

缺点

  1. 备份拷贝前必须停止所有的对mongod的写操作,否则将是一个无效的备份
  2. 不支持副本集时间点级(point in time recovery)恢复,并且很难管理大型分片集群
  3. 备份文件占有更多的空间(包括索引以及重复的底层文件填充和碎片)

mongodump

mongodump备份

mongodump --uri="mongodb://127.0.0.1:27017"                                                                               # 导出整个实例
mongodump --uri="mongodb://127.0.0.1:27017/database" --out=/dump/`date +%Y%m%d` # 导出指定数据库并指定位置
mongodump --uri="mongodb://127.0.0.1:27017/database" --gzip --out=/dump/`date +%Y%m%d` # 导出指定数据库并压缩
mongodump --uri="mongodb://127.0.0.1:27017" --oplog # 导出oplog ,需要开启副本集
mongodump --uri="mongodb://127.0.0.1:27017/database" --excludeCollection=users # 排除指定集合
mongodump --uri="mongodb://127.0.0.1:27017/database" --archive=`date +%Y%m%d`.archive # 导出归档文件

mongodump还原

mongorestore --uri="mongodb://127.0.0.1:27017/" --db=database /dump/20210818/database/                                         # 还原指定数据库
mongorestore --uri="mongodb://127.0.0.1:27017/" --db=database --collection=collection /dump/20210818/database/collection.bson # 还原指定集合
mongorestore --uri="mongodb://127.0.0.1:27017/" --archive=20210818.archive # 从归档文件还原
mongorestore --uri="mongodb://127.0.0.1:27017/" --archive=20210818.archive --dryRun --verbose # 尝试还原
mongorestore --uri="mongodb://127.0.0.1:27017/" --gzip # 从压缩文件中还原
mongorestore --uri="mongodb://127.0.0.1:27017/" --gzip --nsInclude=db1.user* --nsInclude=test.* # 还原指定数据库/集合

优缺点

优点

  1. 备份恢复小型mongoDB集群更简单和效率,备份文件占有的空间更少(只备份文档,不备份索引)
  2. 备份过程中应用可以继续修改数据(记录oplog,通过--oplog选项达到数据状态一致)

缺点

  1. 备份的数据库中不包含local数据库,只备份数据库的文档不备份数据库索引,因此恢复后必须重建索引
  2. 备份恢复大型mogoDB集群不理想(效率不高)
  3. 备份时会影响运行中的mongod的性能(产生网络流量)
  4. 备份的数据比系统内存大时,查询操作会引起页错误
  5. mongodump不同版本的格式不能兼容,不要使用新版本的mongodump备份老版本的数据

问题及解决方法

错误信息 解决方法
Implicit TCP FastOpen unavailable. If TCP FastOpen is required rm -f /tmp/mongodb-27017.sock && service mongod restart

【Mongodb】数据库备份与还原的更多相关文章

  1. PCB MongoDB数据库 备份与还原

    一. MongoDB数据库 备份与还原工具介绍: 数据备份工具  mongodump.exe 数据还原工具   mongorestore.exe 二. MongoDB数据库备份 mongodump - ...

  2. MongoDB数据库备份与还原、单表的导入导出

    -------------------MongoDB备份与恢复------------------- 1.MongoDB数据库备份     1.语法:         mongodump -h dbh ...

  3. mongodb数据库备份迁移 windows -> linux

    mongodb数据库备份迁移 windows -> linux cd 到本机mongodb的安装目录 如: C:\Program Files\MongoDB\Server\3.4\bin 可以发 ...

  4. MongoDb进阶实践之九 Mongodb的备份与还原

    一.引言 前几天写了MongoDB数据库的聚合.一说到“聚合”,用过关系型数据库的人都应该知道它是一个什么东西,主要是用于对数据分类汇总和统计.大家都知道,做为DBA还有另一个重要的任务,那就是对数据 ...

  5. C#.NET SQL数据库备份与还原解决方案

    C#.NET SQL数据库备份与还原解决方案http://www.csframework.com/archive/1/arc-1-20110924-1841.htm 开发框架V2.2(快速开发版)系统 ...

  6. 【C#】数据库备份及还原的实现代码【转载】

    [转载]http://www.codesky.net/article/200908/128600.html C#数据库备份及还原1.在用户的配置时,我们需要列出当前局域网内所有的数据库服务器,并且要列 ...

  7. Mysql数据库备份和还原常用的命令

    Mysql数据库备份和还原常用的命令是进行Mysql数据库备份和还原的关键,没有命令,什么都无从做起,更谈不上什么备份还原,只有给系统这个命令,让它去执行,才能完成Mysql数据库备份和还原的操作,下 ...

  8. [转]MySQL数据库备份和还原的常用命令小结

    MySQL数据库备份和还原的常用命令小结,学习mysql的朋友可以参考下: 备份MySQL数据库的命令 mysqldump -hhostname -uusername -ppassword datab ...

  9. SQL Server 2008数据库备份和还原(还原是必须有完整备份)

    转自lwccc, SQLserver2008数据库备份和还原问题(还原是必须有完整备份) 首先,我要说明的是你必须拥有完整的数据库备份,下面的还原教程,才算有用. 这个连接是某高手的异常恢复方法, 实 ...

随机推荐

  1. 其他:Windows10安装自带的Linux

    1.首先我们要打开Windows功能 2.在这里把勾打上 3.然后打开 设置 --- 更新和安全 --- 针对开发人员 --- (选择)开发人员模式 --- 确定启动 就行了 4.打开PowerShe ...

  2. linux学习之路第三天(vim和vi使用)

    vi和vim编辑器 vi和vim的三种常见模式 1.正常模式 在正常模式下,我们可以使用快捷键 以vim打开一个档案就直接进入一般模式了(这是默认的模式).在这个模式中,你可以使用 上下左右按键来移动 ...

  3. android实现计时器(转)

    新建布局文件activity_main.xml   <?xml version="1.0" encoding="utf-8"?> <Linea ...

  4. ESP32的Flash加密知识

    一.Flash 加密功能用于加密与 ESP32-S2 搭载使用的 SPI Flash 中的内容.启用 Flash 加密功能后,物理读取 SPI Flash 便无法恢复大部分 Flash 内容.通过明文 ...

  5. 如何使用Meter-WebSocketSampler

    安装 JMeter-WebSocketSampler 下载最新的 JMeter-WebSocketSampler,如 JMeterWebSocketSamplers-1.2.1.jar. 下载地址:h ...

  6. MySQL全面瓦解26:代码评审中的MySQL(团队使用)

    数据库对象命名规范 数据库对象 数据库对象是数据库的组成部分,常见的有以下几种: 表(Table ).索引(Index).视图(View).图表(Diagram).缺省值(Default).规则(Ru ...

  7. 【译】.NET 对象分配工具

    随着 Visual Studio 16.10 的发布,性能分析器又有了一个新的分析引擎,.NET 对象分配工具是第一个加入的工具.这为该工具提供了一些新特性,并显著提高了 perf 性能.在你的 C# ...

  8. mpvue开发小程序项目遇到的问题

    mpvue项目 最近用mpvue开发了一个家庭私人医生签约的小程序项目.记录总结一下,开发过程中遇到的一些问题. 关于页面进栈出栈的状态值问题 页面进出栈,会触发onLoad/unLoad事件.出栈不 ...

  9. P7324 [WC2021] 表达式求值

    P7324 [WC2021] 表达式求值 闲话 WC2021 我只得了 20 分,三道题总共 20 分.我是下场了突然后知后觉这件事的,主要原因是我开了 C++11,然后 T1 T2 都没分了.在洛谷 ...

  10. POJ3179 Corral the Cows题解

    我就是个垃圾--一道水题能写这么长时间-- 首先看到题就想到了二维前缀和+二分边长,但地图边长10000,得离散化. 于是这个离散化就把我搞疯了,淦. 这反映出现在基础知识还是不牢固,相当不牢固. 复 ...