mongodb高可用副本集 docker版

现在有三台主机 192.168.122.174 docker1

192.168.122.136 docker2

192.168.122.115 docker 3

docker容器默认的是bridge网络 同主机的容器可以互通 我们下面得用overlay网络

创建overlay网络

docker network create --driver overlay --attachable mongo555

初始化docker swarm

docker1作为主节点初始化

docker swarm init --advertise-addr 192.168.122.174

在主节点上创建 MongoDB 服务

在主节点上创建第一个 MongoDB 服务,并将其配置为副本集的主节点:

docker service create --name mongo1 --network mongo555 \

--constraint 'node.hostname == docker1' \

--publish published=27017,target=27017 \

mongo:4.4.29 mongod --replSet rs0

主节点继续操作

docker service create --name mongo2 --network mongo555 \

--constraint 'node.hostname == docker2' \

--publish published=27018,target=27017 \

mongo:4.4.29 mongod --replSet rs0

docker service create --name mongo3 --network mongo555 \

--constraint 'node.hostname == docker3' \

--publish published=27019,target=27017 \

mongo:4.4.29 mongod --replSet rs0

初始化副本集

连接到 MongoDB 主节点 mongo1,然后初始化副本集:

docker exec -it $(docker ps -q -f name=mongo1) mongo

在 MongoDB shell 中,执行以下命令以添加副本集成员:

rs.initiate({

_id: "rs0",

members: [

{ _id: 0, host: "192.168.122.174:27017" }, // mongo1

{ _id: 1, host: "192.168.122.136:27018" }, // mongo2

{ _id: 2, host: "192.168.122.115:27019" } // mongo3

]

});

这里 mongo2mongo3 的主机地址与端口需要与创建服务时的端口一致。

测试副本集的高可用性

连接到 mongo1,插入测试数据:

use testDB

db.testCollection.insert({ name: "MongoDB Test", createdAt: new Date() });

验证数据在副本集中的同步

可以通过连接到其他节点(mongo2mongo3)来验证数据的同步情况:

连接到 docker2

docker exec -it $(docker ps -q -f name=mongo2) mongo --host 192.168.122.136 --port 27017

use testDB

db.testCollection.find();

连接到docker3

docker exec -it $(docker ps -q -f name=mongo3) mongo --host 192.168.122.115 --port 27017

use testDB

db.testCollection.find();

相关推荐
看山还是山,看水还是。1 小时前
Nginx 的 Http 模块介绍(中)
android·运维·网络·nginx·http
、十一、1 小时前
Linux中ES的安装
linux·运维·elasticsearch
不甘平凡的蜜蜂1 小时前
第三十三篇:TCP协议如何避免/减少网络拥塞,TCP系列八
运维·网络·网络协议·tcp/ip·计算机网络·智能路由器
风虎云龙科研服务器2 小时前
GPU 服务器:高性能计算的核心驱动力
运维·服务器
Mao.O2 小时前
RabbitMQ延迟消息插件安装(Docker环境)
docker·rabbitmq·延迟消息发送
神技圈子2 小时前
【linux经典工具】作为一个合格的开发人员怎能不会tmux
linux·运维·服务器
龙萱坤诺2 小时前
AI自动评论插件V1.3 WordPress插件 自动化评论插件
运维·人工智能·自动化
weixin_448350502 小时前
探索自动化数据清洗技术的前沿趋势
大数据·运维·自动化·数据治理·数据提取
Bold!2 小时前
最新ubuntu22.04 下列软件包有未满足的依赖关系 解决方案
linux·运维·服务器
pyliumy3 小时前
docker的安装配置与基本简单命令
运维·docker·容器