【发布时间】:2019-03-12 13:14:27
【问题描述】:
我可以使用 docker compose.yml 文件设置用户名、密码和创建数据库
version: '3'
services:
mongodb:
image: mongo
volumes:
- /home/temp/finalewd/temp:/var/lib/mongodb
restart: on-failure
ports:
- "27017:27017"
environment:
MONGO_INITDB_ROOT_USERNAME: XXXX
MONGO_INITDB_ROOT_PASSWORD: XXXX
MONGO_INITDB_DATABASE: XXXX
它会打开新的 mongo 容器,数据库为 XXXX ,配置用户名和密码。
但是当我尝试使用如下副本集设置 mongo docker 容器时,
# Use root/example as user/password credentials
version: '3.1'
services:
mongo:
image: mongo
restart: on-failure
volumes:
- /home/temp/mongo/compose/data:/data/db
entrypoint: [ "/usr/bin/mongod", "--bind_ip_all","--replSet", "rs0" ]
environment:
MONGO_INITDB_ROOT_USERNAME: XXXX
MONGO_INITDB_ROOT_PASSWORD: XXXX
MONGO_INITDB_DATABASE: XXXX
使用上面的 docker-compose.yml,它会调出副本集,但不会创建数据库/用户名/密码。
为什么上述情况没有使用环境变量?
任何帮助表示赞赏。
为托马斯的回答添加了内容:
使用 Thomas 的答案中的内容尝试了 docker-compose.yml,一旦 mongo 启动,我尝试了“rs.initiate 但它抛出了已经初始化的状态,所以在这种情况下如何使 mongo 具有主状态?
rs0:OTHER> rs.status();
{
"operationTime" : Timestamp(1552397666, 1),
"ok" : 0,
"errmsg" : "Our replica set config is invalid or we are not a member of it",
"code" : 93,
"codeName" : "InvalidReplicaSetConfig",
"$clusterTime" : {
"clusterTime" : Timestamp(1552397666, 1),
"signature" : {
"hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
"keyId" : NumberLong(0)
}
}
}
rs0:OTHER> rs.initiate()
{
"operationTime" : Timestamp(1552397666, 1),
"ok" : 0,
"errmsg" : "already initialized",
"code" : 23,
"codeName" : "AlreadyInitialized",
"$clusterTime" : {
"clusterTime" : Timestamp(1552397666, 1),
"signature" : {
"hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
"keyId" : NumberLong(0)
}
}
}
rs0:OTHER>
谢谢, 哈利
【问题讨论】:
标签: mongodb docker docker-compose mongodb-query