MongoDB 使用副本集备份添加新的辅助副本成员

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

问题描述:

 

在生产环境中,当辅助副本成员的读压力很大时,可通过添加新的辅助副本成员来缓解压力。

为了能实现主副本成员不停机,并减轻主副本成员的压力,可在辅助副本成员上mongodump备份数据;

为了实现新的辅助副本成员的快速恢复,可直接通过以NFS方式挂载辅助副本成员到做备份操作的辅助副本成员上;

为了保证数据的一致性,在mongodump数据的时候使用—oplog参数,mongorestore时使用—oplogReplay参数;

为了满足后期空间的扩容,通过—directoryperdb参数将数据库分目录存储。

 

解决方法:

 

步骤一:将新机器挂为NFS磁盘

 

参见:CentOS Linux上配置NFS网络文件系统以及客户端使用

 

步骤二:备份辅助副本成员

 

local数据库不会被备份,包括admin在内的其他库会被备份。

1
mongodump --host=192.168.11.1:27017 --oplog -o  /mnt/mongo/mongodata  -u xucy  –p Passw0rd --authenticationDatabase admin > mongodump.log 2>&1 &

 

可通过实时查看日志数据,观察备份进度。

 

1
tail  –f mongodump.log

 

步骤三:在新实例上恢复数据库

 

mongorestore要在mongod未启动的情况下运行,它直接写入文件。

1
mongorestore --host=192.168.11.2:27017 --oplogReplay --dbpath  /data/var/lib/mongodb  --directoryperdb  /nfspool/mongodata  > mongorestore.log 2>&1 &

 

可通过实时查看日志数据,观察恢复进度。

 

1
tail  –f mongorestore.log

 

步骤四:在新实例上重建oplog

 

1.查看主副本的维护窗口和oplog大小:

rs_main:PRIMARY> db.printReplicationInfo()    
configured oplog size:   23862.404296875MB    
log length start to end: 39405secs (10.95hrs)    
oplog first event time:  Sun Feb 08 2015 10:34:07 GMT-0600 (CST)    
oplog last event time:   Sun Feb 08 2015 21:30:52 GMT-0600 (CST)    
now:                     Sun Feb 08 2015 21:30:53 GMT-0600 (CST)

 

2.在新机器上重建oplog:

 

以standalone方式启动,执行如下删除和创建脚本:

1
2
3
4
5
> use  local    
> db.oplog.rs. drop ()    
> db.createCollection( "oplog.rs" , { "capped"  true "size"  : 23 * 1024 * 1024 * 1024})    
或    
> db.runCommand( {  create "oplog.rs" , capped:  true size : (23 * 1024 * 1024 * 1024) } )


步骤五:在新实例上恢复oplog

 

此oplog是mongodump时导出的oplog.bson。

1
mongorestore -d  local  -c oplog.rs  /nfspool/mongodata/oplog .bson

 

步骤六:新实例以副本集启动

 

新实例配置和源副本集添加相同的--replSet和--keyFile参数,以副本集启动

 

步骤七:将该节点添加到复制集集群中

 

1
2
>rs. add (“192.168.11.2:27017”)
{“ok”:1}














































本文转自UltraSQL51CTO博客,原文链接: http://blog.51cto.com/ultrasql/1614361,如需转载请自行联系原作者



相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
6月前
|
NoSQL MongoDB 数据库
MongoDB备份与恢复总结
MongoDB备份与恢复总结
192 0
|
3月前
|
NoSQL 容灾 MongoDB
MongoDB主备副本集方案:两台服务器使用非对称部署的方式实现高可用与容灾备份
在资源受限的情况下,为了实现MongoDB的高可用性,本文探讨了两种在两台服务器上部署MongoDB的方案。方案一是通过主备身份轮换,即一台服务器作为主节点,另一台同时部署备节点和仲裁节点;方案二是利用`priority`设置实现自动主备切换。两者相比,方案二自动化程度更高,适合追求快速故障恢复的场景,而方案一则提供了更多的手动控制选项。文章最后对比了这两种方案与标准三节点副本集的优缺点,指出三节点方案在高可用性和数据一致性方面表现更佳。
186 5
|
4月前
|
存储 NoSQL MongoDB
MongoDB 复制(副本集)
10月更文挑战第17天
60 2
MongoDB 复制(副本集)
|
4月前
|
NoSQL MongoDB 数据库
|
3月前
|
存储 NoSQL MongoDB
【赵渝强老师】MongoDB复制集中的成员
MongoDB复制集通常由一个主库和两个从库组成,可选添加仲裁者。主库负责所有写操作并记录Oplog日志,从库异步同步主库的Oplog日志并应用操作。仲裁者不存储数据,主要用于保证复制集中成员数量为奇数,参与选举投票。视频讲解详见B站链接。
|
5月前
|
存储 NoSQL Shell
MongoDB复制(副本集)总结
这篇文章是关于MongoDB副本集的总结,包括复制原理、设置副本集、案例分析等内容。
58 1
|
6月前
|
NoSQL 网络安全 MongoDB
MongoDB 备份与恢复
MongoDB 中的数据备份和恢复主要依赖于 `mongodump` 和 `mongorestore` 两个命令。`mongodump` 用于备份数据,它可以将数据导出为 BSON 格式的文件,支持多种部署类型,包括独立运行部署、副本集、分片集群等。通过指定不同的参数,如 `--uri`、`--host`、`--port` 等,可以连接到不同的 MongoDB 实例。备份时还可以指定要备份的数据库、集合等。
69 1
|
6月前
|
存储 NoSQL 算法
MongoDB保姆级指南(中):从副本集群、分片集群起航,探索分布式存储的趋势!
本文一起来聊聊MongoDB集群,顺带以MongoDB集群为起点,共同探讨一下分布式存储的发展趋势~
659 15
|
6月前
|
NoSQL MongoDB Windows
MongoDB 副本模式,会映射到本地 127.0.0.1 错误
MongoDB 副本模式,会映射到本地 127.0.0.1 错误
124 0
|
6月前
|
NoSQL MongoDB Windows
MongoDB 读写分离——Windows MongoDB 副本集配置
MongoDB 读写分离——Windows MongoDB 副本集配置
116 0