微信号:yogoup

介绍:网站性能提升与架构设计

使用Docker创建MongoDB复制集

2016-09-05 21:42 杜亦舒

MongoDB复制集由一组MongoDB实例节点组成,包含一个Primary节点、多个Secondary节点


客户端写入的数据会被写入Primary节点,Secondary节点从Primary节点自动同步数据,保持所有成员的数据相同,提供数据库的高可用性

MongoDB复制集的配置非常简单,只需要指定复制集中包含哪些节点就好了

不需要我们指定哪个节点是Primary,会自动选举出来,其他节点便成为Secondary,自动与Primary同步,当Primary坏掉后,也会自动从多个Secondary中重新选举出Primary

下面使用Docker的MongoDB镜像创建3个MongoDB实例,配置成复制集,然后测试一下数据自动复制的情况,并模拟Primary坏掉的情况

前期准备

安装好Docker,获取MongoDB的镜像

docker pull mongo

建议使用阿里云或者daocloud.io的加速器

配置过程

我们会新建一个专属的Docker容器网络,然后创建3个mongo容器(mongo1 mongo2 mongo3),得到3个mongo实例节点,把他们放入专属网络,再对他们3个进行复制集初始化,这样就完成了复制集的创建,最后简单测试一下


  • 新建docker网络


docker network create mongo-cluster

“mongo-cluster” 是这个新建网络的名称,查看一下创建结果

docker network ls



  • 启动3个容器


创建 mongo1

docker run -d \
-p 30001:27017 \
--name mongo1 \
--net mongo-cluster \
mongo mongod --replSet mongo-repliset


说明:

docker run
从镜像启动一个容器

-p 30001:27017
端口映射,容器内的端口 27017 映射到本机的端口 30001

--name mongo1
给这个容器起个名字 “mongo1”

--net mongo-cluster
把这个容器添加到网络 “mongo-cluster”

mongo
要使用的镜像名

mongod --replSet mongo-repliset
容器启动后要运行的命令,执行 mongod 命令,并通过参数指定这个示例加入名为 “mongo-repliset” 的复制集



创建 mongo2

docker run -d -p 30002:27017 --name mongo2 --net mongo-cluster mongo mongod --replSet mongo-repliset

创建 mongo3

docker run -d -p 30003:27017 --name mongo3 --net mongo-cluster mongo mongod --replSet mongo-repliset


查看当前正在运行的容器


docker ps



3个mongo实例成功运行


  • 初始化


现在已经准备好了3个mongo实例,下面就把复制集配置起来

登录到任意一个mongo实例的 shell

docker exec -it mongo1 mongo

添加配置信息

> db = (new Mongo('localhost:27017')).getDB('test')
test
> config = {
      "_id" : "mongo-repliset",
      "members" : [
          {
              "_id" : 0,
              "host" : "mongo1:27017"
          },
          {
              "_id" : 1,
              "host" : "mongo2:27017"
          },
          {
              "_id" : 2,
              "host" : "mongo3:27017"
          }
      ]
  }


config 中第一个 key "_id" 的值 "mongo-repliset" 就是 启动容器时 --replSet 参数的值,"members" 指定了复制集成员的信息

然后使用配置信息初始化复制集

> rs.initiate(config)



执行完成后,复制集就配置完成了,按几次回车键,就会发现shell提示符变了



意味着当前shell 连接的是复制集中的Primary节点

测试


  • 测试数据同步


在Primary中插入了一条测试数据

> db.mycollection.insert({name : 'sample'})



> db.mycollection.find()



然后到其他节点中查看是否包含此数据

退出容器并不让容器停止,使用快捷键 Ctrl+P+Q

登录到mongo2的shell

docker exec -it mongo2 mongo

> db = (new Mongo('localhost:27017')).getDB('test')
> db.setSlaveOk()
> db.mycollection.find()




mongo2 中的数据已经同步,可以用同样的方法到mongo3中查看


  • 模拟Primary当掉


停掉mongo1容器

docker stop mongo1

只剩下 mongo2 和 mongo3



分别登录 mongo2 和 mongo3 的 shell





可以看到 mongo3 被选为了Primary

MongoDB的复制集配置完成



点击 “阅读原文” 查看 文章列表

 
性能与架构 更多文章 MySQL主从复制原理 mysql主从复制配置 轻量级压力测试工具 - AB linux查看CPU和内存的使用情况 页面静态化
猜您喜欢 redis3 集群搭建及注意点 脸书上百万人点赞的漫画:你如何全面、快速的提高工作能力? Java程序员从笨鸟到菜鸟之(三十七)细谈struts2(二)开发第一个struts2的实例 论国际前沿技术团队是如何做科研的 【大型网站的HTTPS实践】 HTTPS协议和原理