前言

数据库的备份非常重要

备份方式

使用Mongodb自带的运维管理工具(Ops Manager)

需要单独部署,比较麻烦和复杂

通过文件系统快照

Linux需要LVM支持
需要开启journal日志
journal日志和数据文件需要在同一个逻辑卷

通过使用cp或者rsync类似命令复制数据目录

复制前需要服务停止写,否则可能会造成文件数据不一致
复制所有的目录或者文件会造成空间的浪费
do not support point in time recovery for replica sets
不适合大分片集群

通过mongodump命令备份

连接mongodb实例读取数据,然后生成BSON文件,然后通过mongorestore恢复数据
对小系统简单高效,不适合大系统的备份和恢复
仅备份文档数据,恢复数据时需要重建索引
备份大数据量时,可能会造成page faults,影响服务性能
默认情况下不备份本地数据库local
备份过程中,数据可能会修改,可以加上--oplog选项,恢复时加上--oplogReplay选项

mongodump命令

用途

备份数据

用法

mongodump options --out path || --archive=filename

常用选项

--host <hostname><:port>, -h <hostname><:port>

连接主机地址

--port <port>

连接端口

--username <username>, -u <username>

登录用户名

--password <password>, -p <password>

登录密码

--authenticationDatabase <dbname>

授权数据库,有指定导出db,则设置为导出db,默认为admin

--db <database>, -d <database>

指定备份的db,未指定导出所有

--collection <collection>, -c <collection>

指定备份的集合,未指定导出所有

--query <json>, -q <json>

导出过滤,未设置导出所有

--gzip

压缩导出数据

--out <path>, -o <path>

导出保存路径

--archive <file or null>

导出数据保存为archive打包文件,导出目录和导出打包文件只能二选一,--archive=打包文件名

--oplog

导出oplog日志,对mongos无效,只对有生成oplog的节点生效

--excludeCollection string

指定哪些集合不备份,有多个则选项使用多次即可

--excludeCollectionsWithPrefix string

根据集合前缀排除不备份的集合,有多个则选项使用多次即可

mongorestore命令

用途

还原数据 跟mongodump搭配使用

用法

mongorestore options <path>
mongorestore options --archive=filepath

常用选项

--host <hostname><:port>, -h <hostname><:port>

连接主机地址

--port <port>

连接端口

--username <username>, -u <username>

授权用户名

--password <password>, -p <password>

授权用户密码

--authenticationDatabase <dbname>

授权数据库

--db <database>, -d <database>

指定导入数据库

--collection <collection>, -c <collection>

指定导入集合

--drop

恢复前删除已存在的集合

--oplogReplay

导入后执行oplog,保证数据的一致性

--gzip

备份文件是否压缩

--archive <=file|null>

导出的是打包文件,指定打包文件路径 --archive=filepath

实践

备份数据

mongodump --host 127.0.0.1 --port 27025 -u root -p root --gzip --archive=mongodb_backup_2017-11-29.tar.gz

恢复数据

mongorestore --host 127.0.0.1 --port 27025 -u root -p root --gzip --nsExclude config* --archive=mongodb_backup_2017-11-29.tar.gz

备注

1. 使用mongorestore命令还原shards集群时需要过滤掉config数据库
2. 不同类型集群备份需要注意的事项和步骤有差异,详情看相关的操作步骤文档
3. 备份方式优先选择顺序 系统快照 > 数据目录备份 > Mongodb工具
4. 可以考虑专门使用一从实例用于备份使用

参考资料

【1】mongodb备份方式
https://docs.mongodb.com/manual/core/backups/

【2】文件系统快照备份和恢复
https://docs.mongodb.com/manual/tutorial/backup-with-filesystem-snapshots/

【3】mongodb命令工具进行备份
https://docs.mongodb.com/manual/tutorial/backup-and-restore-tools/

【4】mongodump备份命令
https://docs.mongodb.com/manual/reference/program/mongodump/

【5】mongorestore恢复命令
https://docs.mongodb.com/manual/reference/program/mongorestore/

【6】副本集集群备份和恢复步骤
https://docs.mongodb.com/manual/tutorial/restore-replica-set-from-backup/

【7】分片集群备份和恢复
https://docs.mongodb.com/manual/administration/backup-sharded-clusters/

【8】单个实例恢复
https://docs.mongodb.com/manual/tutorial/recover-data-following-unexpected-shutdown/

【9】Mongodb运维工具
https://docs.opsmanager.mongodb.com/current/application/

mongodb之备份的更多相关文章

  1. Mongodb数据备份恢复

    Mongodb数据备份恢复 一.MongoDB数据库导入导出操作 1.导出数据库 twangback为备份的文件夹 命令: mongodump -h 127.0.0.1[服务器IP] -d advie ...

  2. mongodb 定时备份

    通过centos 脚步来执行备份操作,使用crontab实现定时功能,并删除指定天数前的备份 具体操作: 1.创建Mongodb数据库备份目录 mkdir -p /home/backup/mongod ...

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

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

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

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

  5. docker安装mongodb并备份

    安装 官方镜像地址: https://hub.docker.com/_/mongo?tab=description 可以查看对应的dockerfile, 通过观察docker-entrypoint.s ...

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

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

  7. MongoDB操作-备份和恢复,导入和导出

    mongodb数据备份和恢复主要分为二种:一种是针对库的mongodump和mongorestore,一种是针对库中表的mongoexport和mongoimport 1. 常用命令格式 mongod ...

  8. mongodb数据库备份恢复-windows系统

    备份语法: mongodump命令脚本语法如下: >mongodump -h dbhost -d dbname -o dbdirectory -h: MongDB所在服务器地址,例如:127.0 ...

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

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

  10. Mongodb自动备份数据库并删除指定天数前的备份

    1.创建Mongodb数据库备份目录 mkdir -p /home/backup/mongod_bak/mongod_bak_now mkdir -p /home/backup/mongod_bak/ ...

随机推荐

  1. tp 3.2 组合查询, 字符串模式查询

    $User = M("User"); // 实例化User对象 $map['id'] = array('neq',1); $map['name'] = 'ok'; $map['_s ...

  2. 看无可看 分治FFT+特征值方程

    题面: 看无可看(see.pas/cpp/c) 题目描述 “What’s left to see when our eyes won’t open?” “若彼此瞑目在即,是否终亦看无可看?” ---- ...

  3. NOIP真题汇总

    想想在NOIP前总得做做真题吧,于是长达一个月的刷题开始了 涉及2008-2016年大部分题目 NOIP [2008] 4/4 1.传纸条:清真的三维DP 2.笨小猴:字符串模拟 3.火柴棒等式:打表 ...

  4. Objective-C——Runtime理解

    动态语言 OC是一门不折不扣的动态语言,所以它的很多机制都是动态运行时决定的.这点和C语言不一样,C语言是静态绑定,也就是编译后所有的一切都已经决定了.这一点和C语言的函数指针有些类似,很多时候函数指 ...

  5. php域名授权实现方法

    php域名授权实现方法 域名授权的目的:维护知识产权. php实现域名授权有很多方法,比如: 1.本地验证法. 2.在线验证法. 不管是那种方法,其实原理都是一样的. 今天我就举一个本地验证的例子! ...

  6. (转)50道JavaScript基础面试题(附答案)

    https://segmentfault.com/a/1190000015288700 1 介绍JavaScript的基本数据类型 Number.String .Boolean .Null.Undef ...

  7. centos7下手动制作trove镜像

    获取镜像 [root@bldattet1 ~]#  wget http://mirrors.aliyun.com/centos/7.5.1804/isos/x86_64/CentOS-7-x86_64 ...

  8. [Windows Server 2003] IIS自带FTP安装及配置方法

    ★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频.★ 本节我们将带领大家:IIS6.0自 ...

  9. 【译】x86程序员手册21-6.3.5为操作系统保留的指令

    6.3.5 Some Instructions are Reserved for Operating System 为操作系统保留的一些指令 Instructions that have the po ...

  10. dubbo之主机绑定

    主机绑定 查找顺序 缺省主机 IP 查找顺序: 通过 LocalHost.getLocalHost() 获取本机地址. 如果是 127.* 等 loopback 地址,则扫描各网卡,获取网卡 IP. ...