启用三个 mongod 建立复制集。

MongoDB 版本选择目前最新的稳定版 3.6.2-jessie

docker run --name mongo0 -d mongo:3.6.2-jessie --replSet "rs0" --bind_ip_all
docker run --name mongo1 -d mongo:3.6.2-jessie --replSet "rs0" --bind_ip_all
docker run --name mongo2 -d mongo:3.6.2-jessie --replSet "rs0" --bind_ip_all

通过 docker inspect 找到三个 mongod 实例的 IPAddress

比如 docker inspect mongo0 | grep IPAddress

又由于端口为 mongod 默认的 27017。所以 mongod 的地址为

  • mongo0: 172.17.0.2:27017
  • mongo1: 172.17.0.3:27017
  • mongo2: 172.17.0.4:27017

初始化复制集

rs.initiate( {
_id : "rs0",
members: [
{ _id: 0, host: "172.17.0.2:27017" },
{ _id: 1, host: "172.17.0.3:27017" },
{ _id: 2, host: "172.17.0.4:27017" }
]
})

根据 replica-set-configuration-document

  • _id:复制集的名称。必须与启动 mongod 的 --replSet 一致
  • members:成员配置文件的列表。
    • members[n]._id:用来识别成员的 id
    • members[n].host:成员对应的 host:port

连接字符串为

mongodb://172.17.0.2:27017,172.17.0.3:27017,172.17.0.4:27017/test?replicaSet=rs0

复制特性

在主节点中插入数据后,从节点中也存在。

mongo mongodb://172.17.0.2:27017,172.17.0.3:27017,172.17.0.4:27017/test?replicaSet=rs0
rs0:PRIMARY> db.order.insert({price: 1})
WriteResult({ "nInserted" : 1 }) mongo --host 172.17.0.3
// 允许当前连接对从库进行读操作
rs0:SECONDARY> db.getMongo().setSlaveOk()
rs0:SECONDARY> db.order.find()
{ "_id" : ObjectId("5a7c5473b74e8cf1bb890979"), "price" : 1 }

重新选举

关闭主节点,会重新选举出新的主节点。

当前主节点为 172.17.0.2:27017

> `rs.status()`

"name" : "172.17.0.2:27017",
"health" : 1,
"stateStr" : "PRIMARY",

通过 docker stop mongo0 关闭它之后,可以看到 172.17.0.2 是不健康状态

"name" : "172.17.0.2:27017",
"health" : 0,
"stateStr" : "(not reachable/healthy)",

主节点变为了 172.17.0.3,期限由 1 变为了 2,表示又经过一次选举,

"term" : NumberLong(2)
...
...
"name" : "172.17.0.3:27017",
"health" : 1,
"stateStr" : "PRIMARY",

docker start mongo0 启动 mongo0 后,172.17.0.2 变为了健康的从节点

"name" : "172.17.0.2:27017",
"health" : 1,
"stateStr" : "SECONDARY",

大部分节点失效

我们关闭两个节点

docker stop mongo0 mongo2

可以看到 172.17.0.2172.17.0.4 都无法连接,而 172.17.0.3 变为了从节点,

整个复制集没有主节点了,无法进行写操作。

"name" : "172.17.0.3:27017",
"health" : 1,
"stateStr" : "SECONDARY", "name" : "172.17.0.2:27017",
"health" : 0,
"stateStr" : "(not reachable/healthy)", "name" : "172.17.0.4:27017",
"health" : 0,
"stateStr" : "(not reachable/healthy)",

设置优先级

先启动之前关闭的节点 docker start mongo0 mongo2

根据 adjust-replica-set-member-priority

将第一个节点的 priority 设置为 2。(需要在主节点中输入以下命令)

cfg = rs.conf()
cfg.members[0].priority = 2
rs.reconfig(cfg)

可以看到不久后,主节点变为 _id: 0

"_id" : 0,
"stateStr" : "PRIMARY",

用于生产环境的注意事项

  • mongod 绑定非 localhost 地址前,考虑开启访问控制或者安全清单上的其他措施
  • 复制集成员的关联性应该小,减小同时出问题的几率

参考

https://docs.mongodb.com/manual/tutorial/deploy-replica-set/

使用 Docker 部署 MongoDB 复制集的更多相关文章

  1. 部署MongoDB复制集(副本集)

    环境 操作系统:Ubuntu 18.04 MongoDB: 4.0.3 服务器 首先部署3台服务器,1台主节点 + 2台从节点 3台服务器的内容ip分别是: 10.140.0.5 (主节点) 10.1 ...

  2. MongoDB 复制集 (一) 成员介绍

       一 MongoDB 复制集简介          MongoDB的复制机制主要分为两种:          Master-Slave    (主从复制)      这个已经不建议使用       ...

  3. mongodb 复制集

    mongodb 复制集 复制集简介 Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点,Mongodb Driver(客户端)的所有数据都写 ...

  4. Raft与MongoDB复制集协议比较

    在一文搞懂raft算法一文中,从raft论文出发,详细介绍了raft的工作流程以及对特殊情况的处理.但算法.协议这种偏抽象的东西,仅仅看论文还是比较难以掌握的,需要看看在工业界的具体实现.本文关注Mo ...

  5. MongoDB复制集

    1.1 MongoDB复制集简介 一组Mongodb复制集,就是一组mongod进程,这些进程维护同一个数据集合.复制集提供了数据冗余和高等级的可靠性,这是生产部署的基础. 1.1.1 复制集的目的 ...

  6. MongoDB复制集技术

    复制集搭建 没毛病: https://www.cnblogs.com/nicolegxt/p/6841442.html?utm_source=itdadao&utm_medium=referr ...

  7. mongodb复制集Replica Set使用简介

    MongoDB高可用 对于MongoDB,可以支持使用单机模式提供服务,但是在实际的生产环境中,单机模式将面临很大的风险,一旦这个数据库服务出现问题,就会导致线上的服务出现错误甚至崩溃.因此,在实际生 ...

  8. MongoDB复制集成员及状态转换

    此文已由作者温正湖授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 复制集(Replica Set)是MongoDB核心组件,相比早期版本采用的主从(Master-Slave) ...

  9. 关于 MongoDB 复制集

    为什么要使用复制集 1.备份数据通过自带的 mongo_dump/mongo_restore 工具也可以实现备份,但是毕竟没有复制集的自动同步备份方便. 2.故障自动转移部署了复制集,当主节点挂了后, ...

随机推荐

  1. JSP--百度百科

    JSP全名为Java Server Pages,中文名叫java服务器页面,其根本是一个简化的Servlet设计,它[1]  是由Sun Microsystems公司倡导.许多公司参与一起建立的一种动 ...

  2. jquery遍历数组的方式

    1,for循环: var arr = new Array(13.5,3,4,5,6); for(var i=0;i<arr.length;i++){ arr[i] = arr[i]/2.0; } ...

  3. Apache Nifi在Windows环境下搭建伪群集及证书登录

    代码地址如下:http://www.demodashi.com/demo/11986.html 前些时间做了关于Apache Nifi分布式集群的搭建分享,但很多时候要搭建分布式集群机器资源是个问题, ...

  4. C# 播放H264裸码流

    要播放H264裸码流,可以分拆为以下三个工作: 1.解码H264裸码流获取YUV数据 2.将YUV数据转换为RGB数据填充图片 3.将获取的图片进行显示 要完成工作1,我们可以直接使用海思的解码库,由 ...

  5. Mac+docker+flask

    1.先要保证mac电脑安装docker 安装的话可以通过命令brew install docker 安装成功后启动,docker 然后在终端执行docker version 或者docker info ...

  6. 写入文件,创建xunlei批量任务

    [php] <?php $arr = array(); $arr[] = 'http://s1.dwstatic.com/group1/M00/83/4A/834a040953745f52e8a ...

  7. [ci] 基于1 上文实现拉取代码后能自动触发sonar-runner实现代码扫描评测,job1完成

    基于1 上文实现拉取代码后能自动触发sonar-runner实现代码扫描评测,job1完成   添加sonar插件 SonarQube Plugin   配置: 系统设置à告知jenkins,sona ...

  8. C# 通过 AppDomain 应用程序域实现程序集动态卸载或加载

    AppDomain 表示应用程序域,它是一个应用程序在其中执行的独立环境.每个应用程序只有一个主应用程序域,但是一个应用程序可以创建多个子应用程序域. 因此可以通过 AppDomain 创建新的应用程 ...

  9. Django学习之第三方储存服务器的使用

    最近,越来越多的公司采用第三方储存来作为视频,图片的储存工具. 国内的像七牛,阿里云的OSS,国外的像亚马逊的S3,微软的azure都是非常有名的第三方储存. 下面以阿里的OSS为例,来介绍第三储存的 ...

  10. Unable to use slave's temporary directory /tmp - Can't create/write to file '/tmp/SQL_LOAD-' (Errcode: 17)

    这个错误时在Mysql主从配置产生的,最后找到这个Mysql的一个bug http://bugs.mysql.com/bug.php?id=62055 bug的主要原因是:打开文件的函数中指定打开模式 ...