Docker 快速搭建 MongoDB 4.x 集群(一主一从)
# 拉取 MongoDB 4.x 镜像
docker pull mongo:4.4
# 启动 MongoDB 主节点容器
docker run --name mongo-master -d mongo:4.4 --replSet "rs0"
# 获取主节点容器的内网 IP
MASTER_IP=$(docker inspect -f '{{ .NetworkSettings.IPAddress }}' mongo-master)
# 启动 MongoDB 从节点容器并配置复制集
docker run --name mongo-slave -d mongo:4.4 --replSet "rs0" --master --slave --source $MASTER_IP
# 进入从节点容器执行 MongoDB Shell 脚本
docker exec -it mongo-slave mongo <<EOF
rs.initiate({
_id: "rs0",
members: [
{ _id: 0, host: "$MASTER_IP:27017" },
{ _id: 1, host: "localhost:27017" }
]
})
EOF
这段代码展示了如何使用Docker快速搭建一个MongoDB 4.x的一主一从复制集。首先,我们从Docker Hub拉取MongoDB 4.4的官方镜像。然后,我们启动主节点的容器,并设置复制集名称为"rs0"。接下来,我们获取主节点容器的内网IP地址,并用这个IP地址启动从节点容器,将其也加入到同一个复制集中。最后,我们通过在从节点容器中执行MongoDB Shell脚本来初始化复制集配置。
评论已关闭