【Mongodb】数据库备份与还原
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 # 挂载
优缺点
优点
- 快速
- 支持时间点的快照备份
- 提供增量备份
缺点
- 需要文件系统支持时间点快照(LVM)
- 需要开启日志功能
- 快照创建整个磁盘的镜像,因此将数据文件,配置,日志放在一个逻辑磁盘上节约空间
复制文件
备份文件
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
优缺点
优点
- 无需文件系统支持快照功能
缺点
- 备份拷贝前必须停止所有的对mongod的写操作,否则将是一个无效的备份
- 不支持副本集时间点级(point in time recovery)恢复,并且很难管理大型分片集群
- 备份文件占有更多的空间(包括索引以及重复的底层文件填充和碎片)
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.* # 还原指定数据库/集合
优缺点
优点
- 备份恢复小型mongoDB集群更简单和效率,备份文件占有的空间更少(只备份文档,不备份索引)
- 备份过程中应用可以继续修改数据(记录oplog,通过--oplog选项达到数据状态一致)
缺点
- 备份的数据库中不包含local数据库,只备份数据库的文档不备份数据库索引,因此恢复后必须重建索引
- 备份恢复大型mogoDB集群不理想(效率不高)
- 备份时会影响运行中的mongod的性能(产生网络流量)
- 备份的数据比系统内存大时,查询操作会引起页错误
- mongodump不同版本的格式不能兼容,不要使用新版本的mongodump备份老版本的数据
问题及解决方法
| 错误信息 | 解决方法 |
|---|---|
| Implicit TCP FastOpen unavailable. If TCP FastOpen is required | rm -f /tmp/mongodb-27017.sock && service mongod restart |
【Mongodb】数据库备份与还原的更多相关文章
- PCB MongoDB数据库 备份与还原
一. MongoDB数据库 备份与还原工具介绍: 数据备份工具 mongodump.exe 数据还原工具 mongorestore.exe 二. MongoDB数据库备份 mongodump - ...
- MongoDB数据库备份与还原、单表的导入导出
-------------------MongoDB备份与恢复------------------- 1.MongoDB数据库备份 1.语法: mongodump -h dbh ...
- mongodb数据库备份迁移 windows -> linux
mongodb数据库备份迁移 windows -> linux cd 到本机mongodb的安装目录 如: C:\Program Files\MongoDB\Server\3.4\bin 可以发 ...
- MongoDb进阶实践之九 Mongodb的备份与还原
一.引言 前几天写了MongoDB数据库的聚合.一说到“聚合”,用过关系型数据库的人都应该知道它是一个什么东西,主要是用于对数据分类汇总和统计.大家都知道,做为DBA还有另一个重要的任务,那就是对数据 ...
- C#.NET SQL数据库备份与还原解决方案
C#.NET SQL数据库备份与还原解决方案http://www.csframework.com/archive/1/arc-1-20110924-1841.htm 开发框架V2.2(快速开发版)系统 ...
- 【C#】数据库备份及还原的实现代码【转载】
[转载]http://www.codesky.net/article/200908/128600.html C#数据库备份及还原1.在用户的配置时,我们需要列出当前局域网内所有的数据库服务器,并且要列 ...
- Mysql数据库备份和还原常用的命令
Mysql数据库备份和还原常用的命令是进行Mysql数据库备份和还原的关键,没有命令,什么都无从做起,更谈不上什么备份还原,只有给系统这个命令,让它去执行,才能完成Mysql数据库备份和还原的操作,下 ...
- [转]MySQL数据库备份和还原的常用命令小结
MySQL数据库备份和还原的常用命令小结,学习mysql的朋友可以参考下: 备份MySQL数据库的命令 mysqldump -hhostname -uusername -ppassword datab ...
- SQL Server 2008数据库备份和还原(还原是必须有完整备份)
转自lwccc, SQLserver2008数据库备份和还原问题(还原是必须有完整备份) 首先,我要说明的是你必须拥有完整的数据库备份,下面的还原教程,才算有用. 这个连接是某高手的异常恢复方法, 实 ...
随机推荐
- 一分钟了解JDBC的构成和原理
JDBC(一组接口组成) : 形式如下: 1:JDBC-ODBC桥接技术(100%不用) 在Windows中有ODBC技术,ODBC指的是开放数据库链接 是由微软提供的数据库连接应用,而Java可以利 ...
- Docker:银河麒麟系统/Ubuntu/arm64-离线安装Docker,配置自启
下载离线包 离线安装包地址:https://download.docker.com/linux/debian/dists/stretch/pool/stable/ 注意: amd64是处理器64位 复 ...
- Centos中安装Node.Js
NodeJs安装有好几种方式: 第一种: 最简单的是用yum命令,可惜我现在用的时候 发现 镜像中没有nodejs:所以这种方式放弃: 第二种:去官网下载源码,然后自己编译:编译过程中可能会出现问题, ...
- python 正则表达式 初级
举例: 1.匹配hello world key = r"<h1>hello world<h1>" #源文本 p1 = r"<h1>.+ ...
- flask的常规使用二
一.路由(router) 路由指定了url 到函数之间的一个映射关系. url ---> flask框架拿到url 的路径部分和路由中的内容进行匹配,如果匹配成功了则执行对应的函数.如果没有找到 ...
- ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: NO)解决办法
问题:ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO) 很久没用这台电脑的mysql ...
- 雪花算法(SnowFlake)Java实现
分布式id生成算法的有很多种,Twitter的SnowFlake就是其中经典的一种. 算法原理 SnowFlake算法生成id的结果是一个64bit大小的整数,它的结构如下图: 1bit,不用,因为二 ...
- python + csv 操作(读写)
import csv"""与excel文件不同,csv文件中:1.数据都没有数据类型,值都是'字符串'2.没有颜色和样式,不能指定单元格测的宽高,不能合并单元格3.没有对 ...
- 测试龙芯 LoongArch .NET之 使用 FastTunnel 做内网穿透远程计算机
龙芯3A5000 已经上市,与龙芯3A5000配套的三大编译器GCC.LLVM.GoLang和三大虚拟机Java.JavaScript..NET均已完成开发,从老伙计哪里搞来一台3A5000 机器,安 ...
- python的模拟算法--打印任务
模拟算法:打印任务 Queue来实现 队列(queue)是一种有次序的数据集合,其特征是新数据项的添加总发生在一端(通常称为"尾rear"端)而现存数据项的移除总发生在另一端(通常 ...