docker mongodb 集群副本主从仲裁

本文介绍了如何使用docker-compose设置MongoDB复制集,包括数据卷映射、端口暴露、环境变量配置,并展示了初始化复制集和添加仲裁节点的步骤。此外,还提到了SpringBoot应用如何连接到这个复制集以及创建数据库用户的操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

docker -compose.yml

version: "3"
services:
  mongo-master:
    image: mongo:4.4.3
    container_name: mongo_m
    restart: always
    volumes:
      -  ./data/mongo_m/data/db:/data
      -  ./mongo/mongodb.key:/data/mongodb.key
    ports:
      - 27018:27017
    environment:
      MONGO_INITDB_ROOT_USERNAME: root
      MONGO_INITDB_ROOT_PASSWORD: 123456
      TZ: Asia/Shanghai
    command: mongod --replSet mongos --keyFile /data/mongodb.key
    entrypoint:
      - bash
      - -c
      - |
        chmod 400 /data/mongodb.key
        chown 999:999 /data/mongodb.key
        exec docker-entrypoint.sh $$@
  mongo-salave:
    image: mongo:4.4.3
    container_name: mongo_s
    restart: always
    volumes:
      -  ./data/mongo_s/data/db:/data
      -  ./mongo/mongodb.key:/data/mongodb.key
    ports:
      - 27019:27017
    environment:
      MONGO_INITDB_ROOT_USERNAME: root
      MONGO_INITDB_ROOT_PASSWORD: 123456
      TZ: Asia/Shanghai
    command: mongod --replSet mongos --keyFile /data/mongodb.key
    entrypoint:
      - bash
      - -c
      - |
        chmod 400 /data/mongodb.key
        chown 999:999 /data/mongodb.key
        exec docker-entrypoint.sh $$@
  mongo-arbiter:
    image: mongo:4.4.3
    container_name: mongo_a
    restart: always
    volumes:
      - ./data/mongo_a/data/db:/data
      - ./mongo/mongodb.key:/data/mongodb.key
    ports:
      - 27020:27017
    environment:
      MONGO_INITDB_ROOT_USERNAME: root
      MONGO_INITDB_ROOT_PASSWORD: 123456
      TZ: Asia/Shanghai
    command: mongod --replSet mongos --keyFile /data/mongodb.key
    entrypoint:
      - bash
      - -c
      - |
        chmod 400 /data/mongodb.key
        chown 999:999 /data/mongodb.key
        exec docker-entrypoint.sh $$@

认证

400权限是要保证安全性,否则mongod启动会报错

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

进入容器

docker-compose up -d 
 docker exec -it mongo /bin/bash

主节点

use admin
db.auth("root","123456")
rs.initiate(
   {
      _id: "mongos",
      version: 1,
      members: [
         { _id: 0, host : "192.168.0.19:27018" },
         { _id: 1, host : "192.168.0.19:27019" }
      ]
   }
)
rs.add("192.168.0.19:27020",true)

springboot 集群使用

spring.data.mongodb.uri=mongodb://192.168.0.19:27018,192.168.0.19:27019,192.168.0.19:27020/data

创建用户

 db.createUser({user:"data",pwd:"123456",roles:[{role:"dbOwner",db:"data"}]})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值