美文网首页
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