Docker搭建高可用的mongodb副本集+分片(Replica Sets+Sharded Cluster)集群

Docker搭建高可用的mongodb副本集+分片(Replica Sets+Sharded Cluster)集群

一,前言

本文主要讲解如何通过docker制作高可用的mongodb副本集+分片(Replica Sets+Sharded Cluster)集群 ,采用各软件版本如下:

工具 版本
操作系统 centos7
docker 1.13.1
mongodb 4.0.0
robo3t Robo 3T 1.1.1

二,目的

本文的目的很简单,使用三台物理机做数据库集群,任意一台宕机之后不会影响线上的业务运转。不会有任何的数据丢失。

三,架构

此次采用的是Replica Sets+Sharded Cluster的集群,具有高可用,故障转移,分布式存储等特性,这里我们采用三台物理机来搭建集群。架构图如下:
在这里插入图片描述
依上图所示我们此次集群配置如下:

  • 三台物理机,每台物理机拥有完整的分片集群配置,都可独立运行
  • 配置服务器:使用使用3个配置服务器确保元数据完整性。
  • 路由(mongos)进程:使用3个路由进程实现平衡,提高客户端接入性能
  • 3 个分片进程:Shard11,Shard12,Shard13 组成一个副本集,提供Sharding 中 Shard1 的功能。
  • 3 个分片进程:Shard21,Shard22,Shard23 组成一个副本集,提供Sharding 中 Shard2 的功能。
    构建一个 mongoDB Sharding Cluster 需要三种角色:shard 服务器(ShardServer)、配置服务器(config Server)、路由进程(Route Process)

Shard 服务器
  shard 服务器即存储实际数据的分片,每个 shard 可以是一个 mongod 实例, 也可以是一组 mongod 实例构成的 Replica Sets.为了实现每个 Shard 内部的故障 自动转换,MongoDB 官方建议每个 shard 为一组 Replica Sets.

配置服务器

为了将一个特定的 collection 存储在多个 shard 中,需要为该 collection 指定 一个 shard key,决定该条记录属于哪个 chunk,配置服务器可以存储以下信息, 每个shard节点的配置信息,每个chunk的shard key范围,chunk在各shard 的分布情况,集群中所有 DB 和 collection 的 sharding 配置信息。

路由(mongos)进程

它是一个前段路由,客户端由此接入,首先询问配置服务器需要到哪个 shard 上查询或保存记录,然后连接相应的 shard 执行操作,最后将结果返回给客户端,客 户端只需要将原本发给 mongod 的查询或更新请求原封不动地发给路由进程,而 不必关心所操作的记录存储在哪个 shard 上。

四,准备工作

以三台机器网络互通为基础条件,需要在/home中创建四个文件夹,且每个文件夹都包含backupconfigdb三个文件夹,其中config

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值