拉取官方镜像
docker pull mongo
启动
docker run --name some-mongo -d mongo:tag
从其他容器连接mongodb
$ docker run -it --link some-mongo:mongo --rm mongo mongo --host mongo test
docker stack 或 compose 配置
version: '3.1'
services:
mongo:
image: mongo
restart: always
environment:
MONGO_INITDB_ROOT_USERNAME: root
MONGO_INITDB_ROOT_PASSWORD: example
mongo-express:
image: mongo-express
restart: always
ports:
- 8081:8081
environment:
ME_CONFIG_MONGODB_ADMINUSERNAME: root
ME_CONFIG_MONGODB_ADMINPASSWORD: example
访问容器及日志
$ docker exec -it some-mongo bash
#The MongoDB Server log is available through Docker's container log:
$ docker logs some-mongo
不使用配置文件配置
mongd 支持大部分参数直接传递。
如:
docker run -it --rm mongo --help docker run --name some-mongo -d mongo --smallfiles
自定义配置文件
$ docker run --name some-mongo -v /my/custom:/etc/mongo -d mongo --config /etc/mongo/mongod.conf
在宿主机上创建配置文件,mount到镜像中, 通过--config 参数指定配置文件启动。
环境变量
启动mongo映像时,可以通过在docker run命令行上传递一个或多个环境变量来调整MongoDB实例的初始化。 请注意,如果使用已包含数据库的数据目录启动容器,则以下任何变量都不会产生任何影响:任何预先存在的数据库在容器启动时始终保持不变。
MONGO_INITDB_ROOT_USERNAME, MONGO_INITDB_ROOT_PASSWORD
这些变量结合使用,创建一个新用户并设置该用户的密码。 此用户在admin身份验证数据库中创建,并具有root角色。 这两个变量都是创建用户所必需的。 如果两者都存在,那么MongoDB将启用身份验证:mongod --auth。 MongoDB中的身份验证相当复杂,通过/docker-entrypoint-initdb.d/将更复杂的用户设置显式留给用户(请参阅下面的初始化新实例)。 以下是使用这两个变量创建MongoDB实例,然后使用mongo cli连接管理身份验证数据库的示例。
$ docker run -d --name some-mongo -e MONGO_INITDB_ROOT_USERNAME=mongoadmin -e MONGO_INITDB_ROOT_PASSWORD=secret mongo
$ docker run -it --rm --link some-mongo:mongo mongo mongo --host mongo -u mongoadmin -p secret --authenticationDatabase admin some-db
> db.getName();
some-db
若不传递这两个变量 或者不设置--auth , 则MongoDB不启用认证 。
MONGO_INITDB_DATABASE
此变量允许您在/docker-entrypoint-initdb.d/*.js中指定要用于创建脚本的数据库的名称(请参阅下面的初始化新实例)。 MongoDB基本上是为“首次使用时创建”而设计的,因此如果您不在JavaScript文件中插入数据,则不会创建任何数据库。
秘钥
作为通过环境变量传递敏感信息的替代方法,_FILE可以附加到先前列出的环境变量,从而使初始化脚本从容器中存在的文件加载这些变量的值。 这可以用于从存储在/ run / secrets / <secret_name>文件中加载密码。 例如:
$ docker run --name some-mongo -e MONGO_INITDB_ROOT_PASSWORD_FILE=/run/secrets/mongo-root -d mongo
目前这只支持 MONGO_INITDB_ROOT_USERNAME and MONGO_INITDB_ROOT_PASSWORD. 。
初始化新实例
当容器首次启动时它会执行/docker-entrypoint-initdb.d 目录下的sh 和js脚本 。 以脚本字母顺序执行。
js脚本将被使用MONGO_INITDB_DATABASE 指定的库或test库执行 。
存储数据文件
在宿主机上创建目录存储 :
$ docker run --name some-mongo -v /my/own/datadir:/data/db -d mongo
实践
docker pull mongo
启动docker 容器:
容器启动mongodb命令:
docker run -d --name mongodb_docker -v /root/mongodb_docker/db:/data/db -p 27017:27017 -e MONGO_INITDB_ROOT_USERNAME=admin -e MONGO_INITDB_ROOT_PASSWORD=admin mongo
容器连接mongodb命令:
docker run -it --rm --link mongodb_docker:mongo mongo mongo --host mongo -u admin -p admin --authenticationDatabase admin
创建数据库 :
use weasel;
创建用户 :
> db.createUser(
... {
... user:"weasel",
... pwd:"weasel123",
... roles: [{ role:"readWrite" , db: "weasel"}]
... });
使用新用户连接:
docker run -it --rm --link mongodb_docker:mongo mongo mongo --host mongo -u weasel -p weasel123 --authenticationDatabase weasel
使用:
use weasel;
> db.test2.insert({"cc":"123", "das":'123444444'});
WriteResult({ "nInserted" : 1 })
>
> db.test2.count()
1
>
> db.test2
db.test2
> db.test2.find({"cc":'123'});
{ "_id" : ObjectId("5b4c3b24099d1b0ef30cc0fb"), "cc" : "123", "das" : "123444444" }