美文网首页
docker 官方mongodb镜像

docker 官方mongodb镜像

作者: 金刚_30bf | 来源:发表于2018-07-16 10:42 被阅读0次

拉取官方镜像

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" }

相关文章

网友评论

      本文标题:docker 官方mongodb镜像

      本文链接:https://www.haomeiwen.com/subject/yysvpftx.html