如何使用Docker创建Mongodb容器
2016-10-19 by dongnan
目标
使用 docker 创建一个 mongodb 容器;
环境
centos 7.2 amd64
docker 1.10.3
操作步骤
下载镜像
docker pull mongo:3
创建容器
注意,由于容器特性我们需要为 mongo容器指定持久化的数据卷,使用-v参数选项:
docker run -tid --name mongo3 \
    -e TZ=Asia/Chongqing \
    -v mongo-data:/data/db \
    mongo:3 --auth
如果希望使用宿主机的端口,方便外部访问到mongo服务,需要使用-p 参数选项:
docker run -tid --name mongo3 \
    -e TZ=Asia/Chongqing \
    -p 27017:27017 \
    -v mongo-data1:/data/db \
    mongo:3 --auth
如果希望创建容器时,自动加入认证信息,可以使用下面的环境变量。
docker run -tid --name mongo3 \
    --restart=always \
    -e TZ=Asia/Chongqing \
    -e MONGO_INITDB_ROOT_USERNAME=root \
    -e MONGO_INITDB_ROOT_PASSWORD=mypassword \
    -p 27017:27017 \
    -v mongo-data2:/data/db \
    mongo:3 --auth
更多环境变量请参考: https://hub.docker.com/_/mongo 。
登录容器
# 登陆 mongodb
docker exec -ti mongo3 mongo admin
MongoDB shell version v3.6.16
#省略...
>
验证容器
尝试在mongo中创建一个库并配置授权用户。
# 查看当前库
> db
admin
# 超级用户
> db.createUser({user:'root',pwd:'password', roles:[{role:'userAdminAnyDatabase', db:'admin'}]})
Successfully added user: {
    "user" : "root",
    "roles" : [
        {
            "role" : "userAdminAnyDatabase",
            "db" : "admin"
        }
    ]
}
# 认证用户
> db.auth('root','password')
1
# 返回值 0:代表授权失败, 1:代表授权成功
# 切换库
> use demo
switched to db demo
# 授权用户
> db.createUser({user:'demo',pwd:'password',roles:[{role:"dbAdmin",db:"demo"}]})
Successfully added user: {
    "user" : "demo",
    "roles" : [
        {
            "role" : "dbAdmin",
            "db" : "demo"
        }
    ]
}