news 2026/4/16 12:17:05

Mongo6 分片集群(单机)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Mongo6 分片集群(单机)

准备目录

mkdir-p /root/Mongo6_Shardingchmod777-R /root/Mongo6_Shardingcd/root/Mongo6_Sharding# 生成证书openssl rand -base64128>/root/Mongo6_Sharding/keyFilechmod600/root/Mongo6_Sharding/keyFile

搭建Config Server

# 创建目录并拷贝证书sudomkdir-p /root/Mongo6_Sharding/mongo6-config-0/dbsudomkdir-p /root/Mongo6_Sharding/mongo6-config-0/configdbsudochmod-R777/root/Mongo6_Sharding/mongo6-config-0cp-a /root/Mongo6_Sharding/keyFile /root/Mongo6_Sharding/mongo6-config-0/configdb/# 配置文件cat>/root/Mongo6_Sharding/mongo6-config-0/configdb/mongod.conf<<EOF net: port: 21000 bindIpAll: true security: keyFile: /data/configdb/keyFile authorization: enabled replication: replSetName: rs-conf-0 sharding: clusterRole: configsvr storage: wiredTiger: engineConfig: cacheSizeGB: 0.5 EOF

搭建Shard-0

# 创建目录并拷贝证书mkdir-p /root/Mongo6_Sharding/mongo6-shard-0/dbmkdir-p /root/Mongo6_Sharding/mongo6-shard-0/configdbchmod-R777/root/Mongo6_Sharding/mongo6-shard-0cp-a /root/Mongo6_Sharding/keyFile /root/Mongo6_Sharding/mongo6-shard-0/configdb/# 配置文件cat>/root/Mongo6_Sharding/mongo6-shard-0/configdb/mongod.conf<<EOF net: port: 22000 bindIpAll: true security: keyFile: /data/configdb/keyFile authorization: enabled replication: replSetName: rs-shard-0 sharding: clusterRole: shardsvr storage: wiredTiger: engineConfig: cacheSizeGB: 0.5 EOF

搭建Shard-1

# 创建目录并拷贝证书mkdir-p /root/Mongo6_Sharding/mongo6-shard-1/dbmkdir-p /root/Mongo6_Sharding/mongo6-shard-1/configdbchmod-R777/root/Mongo6_Sharding/mongo6-shard-1cp-a /root/Mongo6_Sharding/keyFile /root/Mongo6_Sharding/mongo6-shard-1/configdb/# 配置文件cat>/root/Mongo6_Sharding/mongo6-shard-1/configdb/mongod.conf<<EOF net: port: 23000 bindIpAll: true security: keyFile: /data/configdb/keyFile authorization: enabled replication: replSetName: rs-shard-1 sharding: clusterRole: shardsvr storage: wiredTiger: engineConfig: cacheSizeGB: 0.5 EOF

搭建Shard-2

# 创建目录并拷贝证书mkdir-p /root/Mongo6_Sharding/mongo6-shard-2/dbmkdir-p /root/Mongo6_Sharding/mongo6-shard-2/configdbchmod-R777/root/Mongo6_Sharding/mongo6-shard-2cp-a /root/Mongo6_Sharding/keyFile /root/Mongo6_Sharding/mongo6-shard-2/configdb/# 配置文件cat>/root/Mongo6_Sharding/mongo6-shard-2/configdb/mongod.conf<<EOF net: port: 24000 bindIpAll: true security: keyFile: /data/configdb/keyFile authorization: enabled replication: replSetName: rs-shard-2 sharding: clusterRole: shardsvr storage: wiredTiger: engineConfig: cacheSizeGB: 0.5 EOF

搭建Mongos-0

# 创建目录并拷贝证书mkdir-p /root/Mongo6_Sharding/mongos6-0/dbmkdir-p /root/Mongo6_Sharding/mongos6-0/configdbchmod-R777/root/Mongo6_Sharding/mongos6-0cp-a /root/Mongo6_Sharding/keyFile /root/Mongo6_Sharding/mongos6-0/configdb/chown999/root/Mongo6_Sharding/mongos6-0/configdb/keyFile# 配置文件cat>/root/Mongo6_Sharding/mongos6-0/configdb/mongos.conf<<EOF net: port: 27027 bindIpAll: true security: keyFile: /data/configdb/keyFile sharding: configDB: rs-conf-0/172.19.40.9:21000 EOF

docker-compose

# 创建并启动version:'3.8'services:mongo6-config-0:container_name:mongo6-config-0image:mongo:6restart:alwaysnetwork_mode:hostvolumes:-/root/Mongo6_Sharding/mongo6-config-0/db:/data/db-/root/Mongo6_Sharding/mongo6-config-0/configdb:/data/configdb-/etc/localtime:/etc/localtime:rocommand:mongod-f /data/configdb/mongod.confmongo6-shard-0:container_name:mongo6-shard-0image:mongo:6restart:alwaysnetwork_mode:hostvolumes:-/root/Mongo6_Sharding/mongo6-shard-0/db:/data/db-/root/Mongo6_Sharding/mongo6-shard-0/configdb:/data/configdb-/etc/localtime:/etc/localtime:rocommand:mongod-f /data/configdb/mongod.confmongo6-shard-1:container_name:mongo6-shard-1image:mongo:6restart:alwaysnetwork_mode:hostvolumes:-/root/Mongo6_Sharding/mongo6-shard-1/db:/data/db-/root/Mongo6_Sharding/mongo6-shard-1/configdb:/data/configdb-/etc/localtime:/etc/localtime:rocommand:mongod-f /data/configdb/mongod.confmongo6-shard-2:container_name:mongo6-shard-2image:mongo:6restart:alwaysnetwork_mode:hostvolumes:-/root/Mongo6_Sharding/mongo6-shard-2/db:/data/db-/root/Mongo6_Sharding/mongo6-shard-2/configdb:/data/configdb-/etc/localtime:/etc/localtime:rocommand:mongod-f /data/configdb/mongod.confmongos6-0:container_name:mongos6-0image:mongo:6restart:alwaysnetwork_mode:hostvolumes:-/root/Mongo6_Sharding/mongos6-0/db:/data/db-/root/Mongo6_Sharding/mongos6-0/configdb:/data/configdb-/etc/localtime:/etc/localtime:rocommand:mongos-f /data/configdb/mongos.conf

初始化Config Server

#进入容器dockerexec-it mongo6-config-0 /bin/bash#进入mongomongosh --port21000#切换到admin数据库use admin#初始confi server复制集配置rs.initiate({_id:"rs-conf-0", members:[{_id:0,host:"172.19.40.9:21000"}]})db.createUser({user:"admin", pwd:"123456", roles:[{role:"root", db:"admin"}]});

初始化shard-0复制集

#进入容器dockerexec-it mongo6-shard-0 /bin/bash#进入mongomongosh --port22000#切换到admin数据库use admin#初始confi server复制集配置rs.initiate({_id:"rs-shard-0", members:[{_id:0,host:"172.19.40.9:22000"}]})db.createUser({user:"admin", pwd:"123456", roles:[{role:"root", db:"admin"}]});

初始化shard-1复制集

#进入容器dockerexec-it mongo6-shard-1 /bin/bash#进入mongomongosh --port23000#切换到admin数据库use admin#初始confi server复制集配置rs.initiate({_id:"rs-shard-1", members:[{_id:0,host:"172.19.40.9:23000"}]})db.createUser({user:"admin", pwd:"123456", roles:[{role:"root", db:"admin"}]});

初始化shard-2复制集

#进入容器dockerexec-it mongo6-shard-2 /bin/bash#进入mongomongosh --port24000#切换到admin数据库use admin#初始confi server复制集配置rs.initiate({_id:"rs-shard-2", members:[{_id:0,host:"172.19.40.9:24000"}]})db.createUser({user:"admin", pwd:"123456", roles:[{role:"root", db:"admin"}]});

初始化mongos-0配置文件

#登录mongos-0,进行分片配置#进入容器dockerexec-it mongos6-0 /bin/bash#进入mongomongosh --port27027#切换到admin数据库use admin#登录db.auth('admin','123456')#添加分片sh.addShard("rs-shard-0/172.19.40.9:22000");sh.addShard("rs-shard-1/172.19.40.9:23000");sh.addShard("rs-shard-2/172.19.40.9:24000");#对指定库进行分片sh.enableSharding("testdb")# 使用hash分片键sh.shardCollection('testdb.collection',{'field':'hashed'})#移除分片db.adminCommand({removeShard:<shardToRemove>})#分片集群中的每个数据库都有一个主分片。如果您要删除的分片也是集群数据库之一的主分片,则在迁移分片中的所有数据后,您必须手动将数据库移至新分片。#当您删除集群中块分布不均匀的分片时,平衡器首先从排出分片中删除块,然后平衡剩余的不均匀块分布。

分片相关命令,在mongos上使用

# 启用数据库分片:sh.enableSharding("<database>")# 使用hash分片键sh.shardCollection('db.collection',{'field':'hashed'})# 使用递增分片键sh.shardCollection('db.collection',{field:1})# 查看分片是否成功db.collection.stats().sharded# 查看数据分布db.collection.getShardDistribution()

设置平衡器运行窗口时间

use config#设置平衡器窗口时间db.settings.updateOne({_id:"balancer"},{$set:{activeWindow:{start:"<start-time>", stop:"<stop-time>"}}},{upsert:true});#将<开始时间>和<结束时间>替换为使用两位数小时和分钟值(即HH:MM)的时间值,该值指定平衡窗口的开始和结束边界。#对于HH值,使用00-23之间的小时值。#对于MM值,请使用00-59之间的分钟值。#对于内部部署或自管理的分片集群,MongoDB评估相对于配置服务器副本集中主要成员的时区的开始和停止时间。#块只有在到达指定大小才会进行分裂,默认128MB#获取平衡器状态sh.getBalancerState()#启动平衡器sh.startBalancer()#停止平衡器sh.stopBalancer()

分片操作相关命令

#获取所有分片相关信息db.runCommand("getShardMap")
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:14:06

面向对象(下)-接口应用:代理模式 工厂模式

面向对象&#xff08;下&#xff09;-接口应用&#xff1a;代理模式 && 工厂模式 代理模式&#xff08;Proxy&#xff09; 概述&#xff1a;代理模式是Java开发中使用比较多的一种设计模式。代理设计就是为其他对象提供一种代理以控制这个对象的访问。

作者头像 李华
网站建设 2026/4/16 13:55:14

IDEA+mybatis实现基于MyBatis注解的学生管理程序

查看全文&#xff1a;https://www.longkui.site/program/java/ideamybatismybatis2/7183/ 本文主要实现《Java EE企业级应用开发教程&#xff08;SpringSpringMVCMybatis&#xff09;》第2版中的第5章课后习题&#xff1a; 要求&#xff1a; &#xff08;1&#xff09;MyBati…

作者头像 李华
网站建设 2026/4/16 10:13:30

2025年AI面试权威测评:HR招聘提效TOP榜单与选型指南

随着人工智能技术在人力资源领域的深度渗透&#xff0c;AI 面试已从 “可选工具” 升级为 “招聘刚需”&#xff0c;2025 年更是迎来 AI 面试 2.0 时代的全面爆发 —— 招聘不再局限于 “评估现有能力”&#xff0c;更聚焦 “挖掘未来潜力”&#xff0c;降本、提效、精准识人成…

作者头像 李华
网站建设 2026/4/16 12:16:26

STM32F103C8T6微控制器实战指南:从选型到项目开发全解析

STM32F103C8T6微控制器实战指南&#xff1a;从选型到项目开发全解析 【免费下载链接】STM32F103C8T6中文数据手册 本资源文件提供了STM32F103C8T6微控制器的中文数据手册。STM32F103C8T6是一款基于ARM Cortex-M3内核的32位微控制器&#xff0c;具有高性能、低功耗和低电压特性&…

作者头像 李华
网站建设 2026/4/16 12:18:26

仿宋_GB2312字体下载:MAC用户的终极中文排版解决方案

在数字文档排版和平面设计领域&#xff0c;选择一款合适的中文字体至关重要。今天为您推荐的仿宋_GB2312字体资源下载项目&#xff0c;是专为MAC操作系统设计的国家标准编码字体&#xff0c;能够满足您对中文文档排版的高标准要求。无论是撰写论文、设计海报还是制作专业报告&a…

作者头像 李华
网站建设 2026/4/15 19:24:53

《Nature Communications》发表狄拉克涡旋拓扑光子晶体光纤首次实验实现

前言摘要近日&#xff0c;我国科研团队在顶级期刊《自然通讯》上发表了一项具有里程碑意义的研究&#xff1a;全球首次实验制备出“狄拉克涡旋拓扑光子晶体光纤”(https://doi.org/10.1038/s41467-025-65222-z)。该光纤融合拓扑光子学前沿理论与光纤制备技术&#xff0c;实现宽…

作者头像 李华