Docker搭建Mongodb复制集

1. 启动三个Mongodb容器

docker run --name mongo0 -p 8080:27017 -d mongo  --replSet "mg-1234567"
docker run --name mongo1 -p 8081:27017 -d mongo  --replSet "mg-1234567"
docker run --name mongo2 -p 8082:27017 -d mongo  --replSet "mg-1234567"

--replSet为复制集取一个名字

2.配置复制集

选取mongo0做为master,进入容器并连接mongodb数据库

docker exec -it mongo0 bash
mongo

配置复制集

#复制集配置,有报错的话复制出来,改成一行
config = {"_id":"mg-1234567",
		  "members":[
		  {"_id":0,host:"127.0.0.1:8080"},
		  {"_id":1,host:"127.0.0.1:8081"},
		  {"_id":2,host:"127.0.0.1:8082"}
          ]
}
#初始化复制集
rs.initiate(config)
rs.status()

members数组的id必须从0开始

3.验证

mongodb://localhost:8080,localhost:8081,localhost:8082/?replicaSet=mg-1234567&readPreference=secondaryPreferred&serverSelectionTimeoutMS=5000&connectTimeoutMS=10000&3t.uriVersion=3&3t.connection.name=aliyunReplicaSet&3t.alwaysShowAuthDB=true&3t.alwaysShowDBFromUserRole=true

mongodb://localhost:8080,localhost:8081,localhost:8082/?replicaSet=mg-1234567&readPreference=secondaryPreferred&serverSelectionTimeoutMS=5000&connectTimeoutMS=10000&3t.uriVersion=3&3t.connection.name=aliyunReplicaSet&3t.alwaysShowAuthDB=true&3t.alwaysShowDBFromUserRole=true

Docker搭建Mongodb复制集_第1张图片

你可能感兴趣的:(数据库,SpringBoot,Ubuntu,Mongodb,数据库)