news 2026/5/27 14:54:04

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/5/22 13:20:18

最近在帮朋友公司折腾指纹考勤系统,发现用Matlab实现库内指纹比对还挺有意思。今天咱们就手把手拆解这个从预处理到比对的完整流程,顺便聊聊实际开发中遇到的坑

基于matlab的指纹识别库内对比系统 【指纹识别】基于计算机视觉&#xff0c;含GUI界面 步骤&#xff1a;归一化&#xff0c;灰度化&#xff0c;二值化&#xff0c;细化&#xff0c;定位指纹中心点&#xff0c;提取特征&#xff0c;库内比对&#xff0c;结果识别。 功能&#xf…

作者头像 李华
网站建设 2026/5/24 10:49:13

基于Anolis OS的国产CPU性能优化实践,共推多芯混部时代操作系统新范式

2025 年 11 月&#xff0c;备受瞩目的龙蜥大会在北京隆重举行。作为中国开源操作系统生态的重要里程碑&#xff0c;本届大会汇聚了来自芯片、硬件、软件及云服务等领域的顶尖专家与行业代表。会上&#xff0c;阿里云智能集团高级技术专家沈培以“国产 CPU 平台上操作系统和云产…

作者头像 李华
网站建设 2026/5/22 12:59:03

IDEA(2020版)实现HttpServletResponse对象

查看全文&#xff1a;https://www.longkui.site/program/java/idea2020httpservletresponse/7144/ 前序文章&#xff1a; IDEA(2020版)实现Servlet程序 – 每天进步一点点 IDEA(2020版)实现Servlet的生命周期 – 每天进步一点点 IDEA(2020版)实现ServletConfig和ServletCont…

作者头像 李华
网站建设 2026/5/26 9:03:37

基于Java+ vue学生成绩管理系统(源码+数据库+文档)

学生成绩管理 目录 基于springboot vue学生成绩管理系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue学生成绩管理系统 一、前言 博主介绍&…

作者头像 李华
网站建设 2026/5/26 9:51:15

数据集对比

当不确定是不是无意中更改了数据集时&#xff0c;可以做一下数据集对比。import os import json import hashlib import numpy as np from PIL import Image from pathlib import Path import pandas as pd from collections import defaultdictclass DatasetComparator:def __…

作者头像 李华