MongoDB数据库核心的两个特点:第一个特点是副本集的自动切换,保证数据的高可靠、服务的高可用;第二个特点是自动分片、服务的横向扩展能力。

  (一)副本集架构

  MongoDB的副本集是一组保持相同数据集的mongod进程,副本集提供冗余和高可用性,这两个特性是所有生产部署的基础。

  1、复制:复制提供了冗余并增加了数据可用性;提供了一定的容错能力,以防数据库服务器的丢失;在某些场景下提高了读取容量;副本增加了分布式应用程序的数据本地化和可用性。

  2、副本集:

  • 副本集是一组保持相同数据集的mongod实例。
  • 副本集包含多个数据承载节点和一个可选的仲裁节点。
  • 在数据承载节点中只有一个成员是主节点,而其它的都是从节点。
  • 主节点接收所有的写入操作,也就是说一个副本集中只能有一个主节点响应应用的{w:"majority"}write concern。
  • 主节点会通过oplog记录所有在主节点让数据发生改变的操作。
  • 一个基本的3节点副本集架构如下图所示:

 

dock mongodb集群 mongodb集群架构_数据集

  Secondary节点会复制主节点的oplog日志信息,并在自己的节点上应用这些oplog,类似MySQL从库。如果主库出现无法访问的情况,则从库会发起投票,选举出一个新的Primary节点。

  • 副本集之间的复制模式和心跳检测如下图所示:

dock mongodb集群 mongodb集群架构_MongoDB_02

  

  复制过程是主库到从库之间的复制,心跳检测是从库之间的交互过程。

  •  仲裁节点Arbiter

  可以将一个mongod实例作为仲裁节点添加到副本集中,仲裁节点不维护数据集,它的目的是响应其它副本成员的心跳和选举请求。仲裁节点不需要太好的硬件资源,已在新版中不再推荐使用它了。

  主及节点、从节点和仲裁节点的简单示意图如下:

dock mongodb集群 mongodb集群架构_副本集_03

  在生产环境中不建议使用仲裁节点,仲裁节点永远是仲裁节点,主节点可能会降为从节点,从节点可以通过投票变为新的主节点。

阅读是一种修养,分享是一种美德。