MongoDB集群部署(基于docker)
以下是一个使用Docker部署MongoDB副本集的简化示例。这个例子中,我们将部署一个有三个副本的最小MongoDB集。
首先,创建一个名为docker-compose.yml
的文件,内容如下:
version: '3.7'
services:
mongo1:
image: mongo:latest
ports:
- "27017:27017"
command: --replSet rs0
environment:
MONGO_INITDB_ROOT_USERNAME: root
MONGO_INITDB_ROOT_PASSWORD: example
mongo2:
image: mongo:latest
ports:
- "27018:27017"
command: --replSet rs0
environment:
MONGO_INITDB_ROOT_USERNAME: root
MONGO_INITDB_ROOT_PASSWORD: example
mongo3:
image: mongo:latest
ports:
- "27019:27017"
command: --replSet rs0
environment:
MONGO_INITDB_ROOT_USERNAME: root
MONGO_INITDB_ROOT_PASSWORD: example
接下来,在终端中运行以下命令来启动集群:
docker-compose up -d
一旦所有的容器都启动了,连接到其中一个MongoDB实例,并初始化副本集:
docker exec -it mongo1 mongo
> rs.initiate(
{
_id: "rs0",
members: [
{ _id: 0, host: "mongo1:27017" },
{ _id: 1, host: "mongo2:27017" },
{ _id: 2, host: "mongo3:27017" }
]
}
)
这将会启动一个有三个成员的副本集。你可以通过mongo1:27017
, mongo2:27017
, 或mongo3:27017
连接到任何一个成员,并且数据会自动复制到副本集中的其它成员。
请注意,这个例子使用了默认的用户名和密码,并暴露了MongoDB的默认端口。在生产环境中,你应该使用更加安全的配置,例如通过配置文件或环境变量来设置认证和加密相关的参数,并且应当将端口映射到不会被外部访问的端口。
评论已关闭