掌握聚合最新动态了解行业最新趋势
API接口,开发服务,免费咨询服务

使用Docker创建MongoDB复制集

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的复制集配置完成


声明:所有来源为“聚合数据”的内容信息,未经本网许可,不得转载!如对内容有异议或投诉,请与我们联系。邮箱:marketing@think-land.com

0512-88869195
数 据 驱 动 未 来
Data Drives The Future