打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Foursquare:使用MongoDB Replica Sets的三种架构

NoSQL相关论坛 bbs.nosqlfan.com 开通!欢迎参与讨论。

MongoDB 的replication机制除了最普通的Master/Slave模式之外,更强大的就是其支持自动故障转移的Replica Sets模式了。相对于其问题多多的auto-sharding机制,Replica Sets还是相对比较稳定。

作为MongoDB使用大户,Foursquare(简称4sq) 在MongoDB使用上有相当丰富的经验,下面是4sq的一篇文章,描述了Replica Sets机制在4sq 中的几种架构方式。

原文链接:Fun with MongoDB replica sets

1.在原有的Master/Slave 机制上添加一台arbiter

4sq 在早期有一些Master/Slave的MongoDB架构,但这种模式不能实现自动的故障转移,需要在发生故障时手动进行切换。在Replica Sets出现后,这种结构被迁移成为三台机器的Replica Sets:一台Primary,一台Secondary,一台Arbiter。

迁移过程:

修改Master和slave的配置,添加如下几项,并重启MongoDB。

replSet = auxdb
fastsync = true
rest = true

fastsync 使得重启动可以使用到原来的数据文件,重启会非常快。然后再在Primary上用rs.add 和 rs.addArb 将Secondary和Arbiter添加上。就算完成了。

2.一个 Primary用于写,多个Secondary用于读和一个Secondary用于备份

在写多读少的应用中,4sq主要使用了Replica Sets来实现读写分离。通过在连接时指定slaveOk,将读操作放到Secondary上,Primary只承担写操作。同时指定一台priority为0,hidden为true的Secondary来进行备份(这样设置后此机器在读写中都不可见,并且不会被选举为Primary)

3.MongoDB经典配置,上层是Auto-Sharding,每个Sharding结点又是一个Replica Sets

虽然4sq在这上面吃过亏,但很明显他们已经吸取了教训并且在更合理更小心的使用Auto-Sharding这一诱人的功能。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
MongoDB是如何扛住我司千万级QPS的?
MongoDB 复制集模式Replica Sets详解配有演示实例
深入剖析 MongoDB 架构
详解mongodb——架构模式、持久化原理和数据文件存储原理 值得收藏
数据库高可用和分区解决方案-MySQL 篇
Mongodb集群搭建的三种方式
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服