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 network create mongo-cluster
“mongo-cluster” 是这个新建网络的名称,查看一下创建结果
docker network ls
创建 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
支持全球约2.4万个城市地区天气查询,如:天气实况、逐日天气预报、24小时历史天气等
支持识别各类商场、超市及药店的购物小票,包括店名、单号、总金额、消费时间、明细商品名称、单价、数量、金额等信息,可用于商品售卖信息统计、购物中心用户积分兑换及企业内部报销等场景
涉农贷款地址识别,支持对私和对公两种方式。输入地址的行政区划越完整,识别准确度越高。
根据给定的手机号、姓名、身份证、人像图片核验是否一致
通过企业关键词查询企业涉讼详情,如裁判文书、开庭公告、执行公告、失信公告、案件流程等等。