使用docker-compose在MongoDB中创建复制集

7

我正在设置一个 Docker 容器,使用 Docker Compose 初始化 Mongo DB 副本集。但是我无法完成此操作。我已经创建了 Docker Compose 来调用三个 Mongo 实例,但是我遇到解析器问题。以下是我的 Docker-Compose 文件。

    version: '3'
    services:
     mongo-vauto-1:    
        image: "mongo-start"
        build: ./mongo-vAUTO-1
        ports:
          - "30000:27017"
        volumes:
          - ./mongo-vAUTO-1/data:/data/db
        depends_on:
          - "mongo-vauto-2"
          - "mongo-vauto-3"
    
     mongo-vauto-2:
        image: "mongo"
        command: --replSet vAUTO --smallfiles --oplogSize 128
        ports:
          - "40000:27017"
        volumes:
          - ./mongo-vAUTO-2/data:/data/db
    
     mongo-vauto-3:
        image: "mongo"
        command: --replSet vAUTO --smallfiles --oplogSize 128
        ports:
          - "50000:27017"
        volumes:
          - ./mongo-vAUTO-3/data:/data/db
    
     mongo-setup-vauto:
        image: "mongo-setup-vauto"
        build: ./setup
        depends_on:
          - "mongo-vauto-1"

这是我的设置 Dockerfile 文件位于./setup文件夹中,通过它进行调用。

    FROM mongo

    # Create app directory
    WORKDIR vauto-docker/src/config
    
    # Install app dependencies
    COPY replicaSet.js .
    COPY setup.sh .
    
    CMD ["./setup.sh"]

该过程会调用 replicaSet.jssetup.sh。以下是 replicaSet.js 和 setup.sh 文件。

    # replicaSet.js
    rsconf = {
        _id : "vAUTO",
        members: [
            {_id : 0, host : "mongo-vauto-1:27017"},
            {_id : 1, host : "mongo-vauto-2:27017"},
            {_id : 2, host : "mongo-vauto-3:27017"}
        ]
    }
    rs.initiate(rsconf);
    rs.conf();


    #  setup.sh 
    echo *********************************
    echo Starting the replica set
    echo *********************************
    
    sleep 10 | echo waiting for the replica set to be intialized
    mongo mongodb://mongo-vauto-1:27017 replicaSet.js

以下是第一个副本集的 Dockerfile:

Dockerfile 的内容如下:

    FROM mongo
    WORKDIR vauto-docker/src/config
    copy mongo.conf .
    EXPOSE 27017
    CMD ["--config","./mongo.conf"]

我的mongo.conf文件中有以下代码:
    replication:
      oplogSizeMB: 1024
      replSetName: vAUTO

我遇到了以下错误:
    mongo-vauto-1_1      | parse error: Invalid numeric literal at line 1, column 14
    mongo-vauto-1_1      | parse error: Invalid numeric literal at line 1, column 14
    mongo-vauto-1_1      | Error parsing YAML config file: yaml-cpp: error at line 3, column 1: illegal tab when looking for indentation

如果还没有完成,请使用https://codebeautify.org/yaml-validator验证您的组合文件。 - Sameer K
这是一个经过验证的YML文件。 - Dhakshina Moorthy
可能是replica Set mongo docker-compose的重复问题。 - Akshay barahate
2个回答

22

以下是我使用第四个容器在三个 MongoDB 容器运行后初始化副本集的方法:

Docker-compose 文件

    version: '3'
    services:
    
      mongodb1:
        image: mongo:latest
        networks:
          - alphanetwork
        volumes:
          - data1:/data/db
          - config1:/data/configdb
        ports:
          - 30001:27017
        entrypoint: [ "/usr/bin/mongod", "--bind_ip_all", "--replSet", "rs0" ]
    
      mongodb2:
        image: mongo:latest
        networks:
          - alphanetwork
        ports:
          - 30002:27017
        entrypoint: [ "/usr/bin/mongod", "--bind_ip_all", "--replSet", "rs0" ]
    
      mongodb3:
        image: mongo:latest
        networks:
          - alphanetwork
        ports:
          - 30003:27017
        entrypoint: [ "/usr/bin/mongod", "--bind_ip_all", "--replSet", "rs0" ]
    
      mongoclient:
        image: mongo
        networks:
          - alphanetwork
        depends_on:
          - mongodb1
          - mongodb2
          - mongodb3
        volumes:
          - ./deployment_scripts:/deployment_scripts
        entrypoint:
          - /deployment_scripts/initiate_replica.sh
    
    networks:
      alphanetwork:
    
    volumes:
      data1:
      config1:

initiate_replica.sh

    #!/bin/bash
    
    echo "Starting replica set initialize"
    until mongo --host mongodb1 --eval "print(\"waited for connection\")"
    do
        sleep 2
    done
    echo "Connection finished"
    echo "Creating replica set"
    mongo --host mongodb1 <<EOF
    rs.initiate(
      {
        _id : 'rs0',
        members: [
          { _id : 0, host : "mongodb1:27017" },
          { _id : 1, host : "mongodb2:27017" },
          { _id : 2, host : "mongodb3:27017" }
        ]
      }
    )
    EOF
    echo "replica set created"

别忘了 chmod +x ./deployment_scripts/initiate_replica.sh,以便让 Docker 获得执行权限。


3
最佳解决方案。应该被选为正确答案。 - alete
唯一有效的简单解决方案。谢谢! - Latchy
这对我的需求非常有效!我需要使用Mongo测试事务,这使我能够在本地启动一个副本集。谢谢! - Jacob
在使用最新的MongoDB Docker镜像时,你应该在bash脚本中使用mongosh而不是mongo - undefined

2
基于@ToDevAndBeyond的解决方案,这是具有访问控制的工作解决方案(在本例中,该解决方案仅有两个实例):
Docker-compose文件
version: '3.5'
services:
  mongodb1:
    image: myMongoImage
    command: [ "--replSet", "rs0", "--bind_ip_all", "--keyFile", "/data/custom_config/mongodb.key", "--port", "27018" ]
    network_mode: host
    ports:
      - 27018:27018
    restart: always
    environment:
      MONGO_INITDB_ROOT_USERNAME: <username>
      MONGO_INITDB_ROOT_PASSWORD: <password>
  mongodb2:
    image: myMongoImage
    command: sh -c 'sleep 5 && /usr/local/bin/docker-entrypoint.sh --replSet rs0 --bind_ip_all --keyFile /data/custom_config/mongodb.key --port 27019'
    network_mode: host
    ports:
      - 27019:27019
    restart: always
    environment:
      MONGO_INITDB_ROOT_USERNAME: <username>
      MONGO_INITDB_ROOT_PASSWORD: <password>
  mongoclient:
    image: mongo:4.0.23-xenial
    network_mode: host
    depends_on:
      - mongodb1
      - mongodb2
    volumes:
      - <path_to_script_folder>:/deployment_scripts
    entrypoint:
      - /deployment_scripts/initiate_replica.sh

initiate_replica.sh

#!/bin/bash

sleep 10

echo "Starting replica set initialize"
until mongo  --username <username> --password <password> --host localhost --port 27018 --eval "print(\"waited for connection\")"
do
    sleep 2
done
echo "Connection finished"
echo "Creating replica set"
mongo  --username <username> --password <password> --host localhost --port 27018 <<EOF
rs.initiate(
  {
    _id : 'rs0',
    members: [
      { _id : 0, host : "localhost:27018" },
      { _id : 1, host : "localhost:27019" }
    ]
  }
)
EOF
echo "replica set created"

Dockerfile(我的Mongo镜像)

FROM mongo:4.0.23-xenial

RUN cd /
RUN mkdir /data/custom_config/
RUN openssl rand -base64 741 > /data/custom_config/mongodb.key
RUN chmod 600 /data/custom_config/mongodb.key
RUN chown mongodb:mongodb /data/custom_config/mongodb.key

重要提示:在启动过程中,mongodb服务器会启动两次;第一个mongodb服务器用于创建用户,始终在端口27017上运行,而另一个则在27018或27019上运行;由于network_mode=host,两个docker容器必须延迟启动,否则两者都将尝试在端口27017上启动服务器,其中一个将悄悄失败。

如上所述,请不要忘记chmod +x ./deployment_scripts/initiate_replica.sh以授予docker执行权限。

还有一点需要注意的是,./deployment_scripts/initiate_replica.sh的所有者和组为mongodb(您可以在Dockerfile中看到)

希望对某人有所帮助。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接