docker-compose部署mongodb副本集(无需初始化)

本文详细介绍了如何使用DockerCompose在两个节点上部署MongoDB的副本集,包括仲裁节点的设置,密钥文件的生成,以及数据库的初始化和数据同步。部署过程中涉及环境变量配置、权限管理及副本集的初始化。
摘要由CSDN通过智能技术生成

部署两节点 两副本,一仲裁

192.168.171.101 primary,arbiter
192.168.171.102 secondary

部署流程

1 配置密钥

主节点上操作。复制到其他节点

openssl rand -base64 756 > mongodb.key
chmod 400 mongodb.key

2 生成密码:(这里为方便不做此步。)

openssl rand -hex 15
随机生成15个字符的16位进制的密码

3 docker-compose

101:

version: '3.3'

services:
  mongo-primary:
    image: mongo:4.4.2
    volumes:
      - ./db:/data/db
      - ./mongodb.key:/data/mongodb.key
    user: root
    environment:
      - MONGO_INITDB_ROOT_USERNAME=admin
      - MONGO_INITDB_ROOT_PASSWORD=admin
    container_name: mongo-pri
    ports:
      - 27017:27017
    command: mongod --replSet mongoReplSet --keyFile /data/mongodb.key
    restart: always
    entrypoint:
      - bash
      - -c
      - |
        chmod 400 /data/mongodb.key
        chown 999:999 /data/mongodb.key
        exec docker-entrypoint.sh $$@
  mongo-arbiter:
    image: mongo:4.4.2
    volumes:
      - ./arb_db:/data/db
      - ./mongodb.key:/data/mongodb.key
    user: root
    environment:
      - MONGO_INITDB_ROOT_USERNAME=admin
      - MONGO_INITDB_ROOT_PASSWORD=admin
    container_name: mongo-arb
    ports:
      - 27018:27017
    command: mongod --replSet mongoReplSet --keyFile /data/mongodb.key
    restart: always
    entrypoint:
      - bash
      - -c
      - |
        chmod 400 /data/mongodb.key
        chown 999:999 /data/mongodb.key
        exec docker-entrypoint.sh $$@
  mongo-init:
    image: mongo:4.4.2
    depends_on:
      - mongo-primary
      - mongo-arbiter
    restart: on-failure:5
    command:
      - mongo
      - mongodb://admin:admin@192.168.171.101:27017/admin
      - --eval
      - 'rs.initiate({_id:"mongoReplSet",members:[{_id:1,host:"192.168.171.101:27017",priority:3},{_id:2,host:"192.168.171.102:27017",priority:2},{_id:3,host:"192.168.171.101:37019",arbiterOnly:true}}]})'

priority:数值越大,越先可能被选为primary

102:

version: '3.3'

services:
  mongo-sec1:
    image: mongo:4.4.2
    volumes:
      - ./db:/data/db
      - ./mongodb.key:/data/mongodb.key
    user: root
    environment:
      - MONGO_INITDB_ROOT_USERNAME=admin
      - MONGO_INITDB_ROOT_PASSWORD=admin
    container_name: mongo-sec1
    ports:
      - 27017:27017
    command: mongod --replSet mongoReplSet --keyFile /data/mongodb.key
    restart: always
    entrypoint:
      - bash
      - -c
      - |
        chmod 400 /data/mongodb.key
        chown 999:999 /data/mongodb.key
        exec docker-entrypoint.sh $$@
  mongo-arbiter:
    image: mongo:4.4.2
    volumes:
      - ./arb_db:/data/db
      - ./mongodb.key:/data/mongodb.key
    user: root
    environment:
      - MONGO_INITDB_ROOT_USERNAME=admin
      - MONGO_INITDB_ROOT_PASSWORD=admin
    container_name: mongo-arb1
    ports:
      - 27018:27017
    command: mongod --replSet mongoReplSet --keyFile /data/mongodb.key
    restart: always
    entrypoint:
      - bash
      - -c
      - |
        chmod 400 /data/mongodb.key
        chown 999:999 /data/mongodb.key
        exec docker-entrypoint.sh $$@

注意:需要先启动102节点上的服务。否则101上的mongo-init会因找不到102而发生错误。

测试

在这里插入图片描述

在这里插入图片描述

在主mongo上插入数据

use test
db.use.insert({"username": "visionwang",age:26})

在从节点上查看

mongoReplSet:SECONDARY> rs.slaveOk();
 #从节点默认不可读写,明确从节点参数,暂时设置为可读
use test      #切换到test库
db.use.find();   #查看数据

在这里插入图片描述
到这里mongodb的副本部署已经完成。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值