docker快速搭建mongodb的分片集群

docker快速搭建mongodb的分片集群

1.准备

javascript 复制代码
// 创建网络:
docker network create mongo-shard

2.启动Config-Server:

配置服务器(config server),这是MongoDB分片集群中的一部分。

javascript 复制代码
// 启动congfig-server
docker run -d --net mongo-shard --name config-server -p 27019:27019 -v /mongodb/config-server/db:/data/db -v /mongodb/config-server/log:/var/log/mongodb -e mongo_initdb_root_username=root -e mongo_initdb_root_password=root mongo:4.4.10 --configsvr --replSet configrs
// 进入容器内部
docker exec -it config-server bash
// 连接config-server.默认端口20719
mongo --port 27019
// 初始化config-server
rs.initiate({_id: "configrs", configsvr: true, members: [{_id: 0, host: "config-server:27019"}]})
  • docker run: 运行一个新的Docker容器。
  • -d: 在后台运行容器。
  • --net mongo-shard: 指定容器使用名为mongo-shard的自定义网络。
  • --name config-server: 为容器指定一个名称,即config-server。
  • -p 27019:27019: 将容器的27019端口映射到主机的27019端口。
  • -v /mongodb/config-server/db:/data/db: 挂载一个主机上的目>录/mongodb/config-server/db到容器内的/data/db目录,用于持久化数据库数据。
  • -v /mongodb/config-server/log:/var/log/mongodb: 挂载一个主机上的目录/mongodb/config-server/log到容器内的/var/log/mongodb目录,用于持久化MongoDB的日志文件。
  • -e mongo_initdb_root_username=root: 设置环境变量,用于初始化数据库时设置root用户名。
  • -e mongo_initdb_root_password=root: 设置环境变量,用于初始化数据库时设置root用户的密码。
  • mongo:4.4.10: 使用MongoDB 4.4.10版本的Docker镜像。
  • --configsvr: 指定这个MongoDB实例作为配置服务器运行。
  • --replSet configrs: 指定这个配置服务器属于名为configrs的复制集。

3.启动三个Shard Server:

javascript 复制代码
// 启动容器
docker run -d --net mongo-shard --name shard1 -p 27017:27018 -v /mongodb/shard1/db:/data/db -v /mongodb/shard1/log:/var/log/mongodb -e mongo_initdb_root_username=root -e mongo_initdb_root_password=root mongo:4.4.10 --shardsvr --replSet shard1rs
docker run -d --net mongo-shard --name shard2 -p 27018:27018 -v /mongodb/shard2/db:/data/db -v /mongodb/shard2/log:/var/log/mongodb -e mongo_initdb_root_username=root -e mongo_initdb_root_password=root mongo:4.4.10 --shardsvr --replSet shard1rs
docker run -d --net mongo-shard --name shard3 -p 27020:27018 -v /mongodb/shard3/db:/data/db -v /mongodb/shard3/log:/var/log/mongodb -e mongo_initdb_root_username=root -e mongo_initdb_root_password=root mongo:4.4.10 --shardsvr --replSet shard1rs
// 进入容器内部
docker exec -it shard1 bash
// 连接shard server
mongo --port 27018
// 初始化shard集群
rs.initiate({_id: "shard1rs", members: [{_id: 0, host: "shard1:27018"},{_id: 1, host: "shard2:27018"},{_id: 2, host: "shard3:27018"}]})
  • --shardsvr: 指定这个MongoDB实例作为分片服务器运行。
  • --replSet shard1rs: 指定这个分片服务器属于名为shard1rs的复制集。

4.启动一个Router(mongos):

mongos:MongoDB的路由服务。mongos是MongoDB分片集群中的一个组件,用于路由客户端请求到正确的分片

javascript 复制代码
//启动mongos
docker run -d --net mongo-shard --name mongos -p 27021:27017 -v /mongodb/mongos/db:/data/db -v /mongodb/mongos/log:/var/log/mongodb -e mongo_initdb_root_username=root -e mongo_initdb_root_password=root mongo:4.4.10 mongos --configdb configrs/config-server:27019

// 连接到Router,添加Shard:
docker exec -it mongos bash
mongo --port 27017

// 在MongoDB shell中执行:
sh.addShard("shard1rs/shard1:27018")
sh.addShard("shard1rs/shard2:27018")
sh.addShard("shard1rs/shard3:27018")
  • docker run: 运行一个新的Docker容器。
  • -d: 在后台运行容器。
  • --net mongo-shard: 指定容器使用名为mongo-shard的自定义网络。
  • --name mongos: 为容器指定一个名称,即mongos。
  • -p 27021:27017: 将容器的27017端口映射到主机的27021端口。
  • -v /mongodb/mongos/db:/data/db: 挂载一个主机上的目录/mongodb/mongos/db到容器内的/data/db目录,用于持久化数据库数据。
  • -v /mongodb/mongos/log:/var/log/mongodb: 挂载一个主机上的目录/mongodb/mongos/log到容器内的/var/log/mongodb目录,用于持久化MongoDB的日志文件。
  • -e mongo_initdb_root_username=root: 设置环境变量,用于初始化数据库时设置root用户名。
  • -e mongo_initdb_root_password=root: 设置环境变量,用于初始化数据库时设置root用户的密码。
  • mongo:4.4.10: 使用MongoDB 4.4.10版本的Docker镜像。
    mongos: 运行mongos服务。
  • --configdb configrs/config-server:27019: 指定配置数据库的连接字符串,其中configrs是复制集的名称,config-server是配置服务器的地址和端口
  • 请注意,上述步骤是简化版本,实际生产环境可能需要更多的配置和安全性措施。在实际环境中,确保使用适当的身份验证和加密来保护MongoDB实例
相关推荐
小张是铁粉2 小时前
docker学习二天之镜像操作与容器操作
学习·docker·容器
烟雨书信2 小时前
Docker文件操作、数据卷、挂载
运维·docker·容器
IT成长日记2 小时前
【Docker基础】Docker数据卷管理:docker volume prune及其参数详解
运维·docker·容器·volume·prune
这儿有一堆花2 小时前
Docker编译环境搭建与开发实战指南
运维·docker·容器
LuckyLay2 小时前
Compose 高级用法详解——AI教你学Docker
运维·docker·容器
Uluoyu2 小时前
redisSearch docker安装
运维·redis·docker·容器
IT成长日记6 小时前
【Docker基础】Docker数据持久化与卷(Volume)介绍
运维·docker·容器·数据持久化·volume·
热爱生活的猴子6 小时前
阿里云服务器正确配置 Docker 国内镜像的方法
服务器·阿里云·docker
FrankYoou10 小时前
Jenkins 与 GitLab CI/CD 的核心对比
java·docker
隆里卡那唔11 小时前
在dify中通过http请求neo4j时为什么需要将localhost变为host.docker.internal
http·docker·neo4j