一、概述

分片是一种在多台机器上分配数据的方法。MongoDB使用分片来支持具有非常大的数据集和高吞吐量操作。有两种解决系统增长的方法:垂直扩展和水平扩展。

垂直扩展涉及增加单个服务器的容量,例如使用更强大的CPU,增加更多RAM或增加存储空间量等。介于硬件成本和硬件性能单机器能支持的并发访问和存储容量是有限的。因此,垂直扩展是存在最大上限的。

水平扩展包括将系统数据集和负载分配到多个服务器上,添加额外的服务器以根据需要增加容量。尽管单台机器的整体速度或容量可能并不高,但每台机器可处理整个工作负载的一部分,效率可能会高于单台高速大容量服务器。而且很多时候可以选择成本很低的普通PC电脑;与单台机器的高端硬件相比,总成本可能会更低,但是增加了维护的复杂性。

MongoDB版本:3.6

二、分片集群架构

1).分片

分片的含义是指将数据拆分,将其分散存放在不同的机器上的过程,MongoDB的分片机制允许你创建一个包含许多台机器的集群,将数据子集分散在集群中,每一个分片维护着一个数据集合的子集。与单机服务器和副本集相比,使用分片集群架构可以使应用程序具有更大的数据处理能力。

备注:每一个分片都是由一个副本集组成。从MongoDB 3.6版本之后,分片必须是副本集。

2).配置服务器

配置服务器是整个集群的大脑,保存着集群和分片的元数据库,比如:分片信息、群集数据库信息、分片集合信息、块信息、平衡器信息、版本信息、群集操作日志、相关设置信息等。因此配置服务器数据必须保存在非易失性驱动器上。每个配置服务器都应该位于单独的物理机器上,最好是异地分布,同时还需要启用日志功能。

备注:在Mongos3.4版本之后,配置服务器也必须是副本集。

3).Mongos进程

Mongos提供客户端应用程序和分片群集之间的接口。

部署多个mongos支持高可用性和可伸缩性;常见的模式是mongos在每个应用程序服务器上部署一个 ,在每个应用程序服务器上部署一个 可减少应用程序和之间的网络延迟。或者您可以专用的服务器上部署mongos。大型部署一般使用此方法,因为它将客户端应用程序服务器与mongos分离 这可以更好地控制mongod实例的连接数量。

可以在主分片上部署mongos,mongos不会与mongod实例共享内存。需要注意内存争用可能导致的问题。

理论上可以部署无数个mongos路由。但是由于mongos路由经常与配置服务器进行通信,所以在增加mongos数量时应该密切监视配置服务器的性能。如果您看到性能下降,应该现在mongos的数量

三、部署分片

1).环境

192.168.137.10:rs-a-1:27010;rs-a-2:27011;rs-a-3:27012

192.168.137.20:rs-b-1:28010;rs-b-2:28011;rs-b-3:28012

192.168.137.30:config-1:29010,config-2:29011;config-3:29012;mongos:30000

rs-a分片副本集配置

--------------rs-a-1配置-------------------------
pidfilepath = /rs-a-/mongod.pid
logpath = /rs-a-/data/log/mongod.log
dbpath = /rs-a-/data/db
logappend = true
port =
fork = true
auth = true
replSet = rs-a
shardsvr = true
keyFile = /rs-a-/autokey --------------rs-a-2配置-------------------------
pidfilepath = /rs-a-/mongod.pid
logpath = /rs-a-/data/log/mongod.log
dbpath = /rs-a-/data/db
logappend = true
port =
fork = true
auth = true
replSet = rs-a
shardsvr = true
keyFile = /rs-a-/autokey --------------rs-a-3配置-------------------------
logpath = /rs-a-/data/log/mongod.log
dbpath = /rs-a-/data/db
logappend = true
port =
fork = true
auth = true
replSet = rs-a
shardsvr = true
keyFile = /rs-a-/autokey

rs-b分片副本集配置

--------------rs-b-1配置-------------------------
pidfilepath = /rs-b-/mongod.pid
logpath = /rs-b-/data/log/mongod.log
dbpath = /rs-b-/data/db
logappend = true
port =
fork = true
auth = true
replSet = rs-b
shardsvr = true
keyFile = /rs-b-/autokey --------------rs-b-2配置-------------------------
pidfilepath = /rs-b-/mongod.pid
logpath = /rs-b-/data/log/mongod.log
dbpath = /rs-b-/data/db
logappend = true
port =
fork = true
auth = true
replSet = rs-b
shardsvr = true
keyFile = /rs-b-/autokey --------------rs-b-3配置-------------------------
pidfilepath = /rs-b-/mongod.pid
logpath = /rs-b-/data/log/mongod.log
dbpath = /rs-b-/data/db
logappend = true
port =
fork = true
auth = true
replSet = rs-b
shardsvr = true
keyFile = /rs-b-/autokey

config配置服务器配置

--------------config-1配置-------------------------
pidfilepath = /config-/mongod.pid
logpath = /config-/data/log/mongod.log
dbpath = /config-/data/db
logappend = true
port =
fork = true
auth = true
configsvr = true
replSet = config
keyFile = /config-/autokey --------------config-2配置-------------------------
pidfilepath = /config-/mongod.pid
logpath = /config-/data/log/mongod.log
dbpath = /config-/data/db
logappend = true
port =
fork = true
auth = true
configsvr = true
replSet = config
keyFile = /config-/autokey --------------config-3配置-------------------------
logpath = /config-/data/log/mongod.log
dbpath = /config-/data/db
logappend = true
port =
fork = true
auth = true
configsvr = true
replSet = config
keyFile = /config-/autokey

Mongos路由配置

configdb = config/192.168.137.30:,192.168.137.30:,192.168.137.30:
port =
logpath = /mongos/log/route.log
bind_ip = 192.168.137.30,127.0.0.1
logappend = true
fork = true
keyFile = /mongos/autokey
maxConns=

备注:

1.当前为了便于理解所以节点的分布不合理,如果是真实的生成环境每个数据节点都应该分开。

2.注意分片的分片节点的配置文件中需要增加“shardsvr = true”,conf节点需要增加"configsvr = true"的启动配置参数;可以参考yaml格式:https://www.cnblogs.com/chenmh/p/9544346.html

2).分片配置

1.启动所有分片副本集(rs-a,rs-b)和配置服务器(config)

具体方法可以参考我前面写的搭建副本集的文章。

MongoDB 搭建可复制群集:http://www.cnblogs.com/chenmh/p/8484049.html

2.启动mongos路由

mongos --config /mongos/mongos.conf

3.分片配置

登入验证

mongo --port
use admin
db.auth("dba","dba")

添加分片

sh.addShard("rs-a/192.168.137.10:27010,192.168.137.10:27011,192.168.137.10:27012");
sh.addShard("rs-b/192.168.137.20:28010,192.168.137.20:28011,192.168.137.20:28012");

文档分片

use admin
sh.enableSharding("test");
sh.shardCollection("test.person",{_id:});
sh.enableSharding("news");
sh.shardCollection("news.person",{"username":"hashed"});

备注:这里的分片方式有1,-1,hashed三种;

1.如果分片集合是空集合那么可以不需要提前创建索引,对集合分片默认会对分片字段创建索引。

2.如果分片集合是非空集合那么需要手动创建对应分片类型的索引。

3.如果分片集合存在唯一索引,那么分片必须是唯一索引上的键。

具体参考:https://docs.mongodb.com/manual/reference/method/sh.shardCollection/index.html

插入测试数据

use test;
for(var i=;i<;i++){ db.person.insert({"_id":i,"username":"user"+i,"createdate":new Date()})}
use news;
for(var i=;i<;i++){ db.person.insert({"_id":i,"username":"user"+i,"createdate":new Date()})}

3).查询

sh.status();

备注:可以看到rs-a;rs-b两个分片上的数据库块都是一样的,分布的很均匀,接下来看一下增加一个新分片之后数据库块的分布情况。

4).添加新分片

备注:添加新的分片之后,mongos再一次移动了数据块,保证数据块在每一个分片上都均匀的分布。数据库的移动是异步的。

四、总结

Mongos采取异步的方式将数据块移动到其它的分片,数据块不能设的太小否则对于密集写的系统所有的写操作会集中到一个分片上,最后异步移动数据块到其它的分片。

备注:

作者:pursuer.chen

博客:http://www.cnblogs.com/chenmh

本站点所有随笔都是原创,欢迎大家转载;但转载时必须注明文章来源,且在文章开头明显处给明链接,否则保留追究责任的权利。

《欢迎交流讨论》

MongoDB 分片集群搭建的更多相关文章

  1. MongoDB分片集群搭建及扩容

    ### 实验:分片集群搭建及扩容#### 实验目标及流程 * 目标:学习如何搭建一个两分片的分片集群 * 环境:3台Linux虚拟机器,4Core 8GB * 步骤: * 配置域名解析 * 准备分片目 ...

  2. MongoDB 分片集群实战

    背景 在如今的互联网环境下,海量数据已随处可见并且还在不断增长,对于如何存储处理海量数据,比较常见的方法有两种: 垂直扩展:通过增加单台服务器的配置,例如使用更强悍的 CPU.更大的内存.更大容量的磁 ...

  3. 分布式文档存储数据库之MongoDB分片集群

    前文我们聊到了mongodb的副本集以及配置副本集,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/13953598.html:今天我们来聊下mongodb的分片 ...

  4. 搭建MongoDB分片集群

    在部门服务器搭建MongoDB分片集群,记录整个操作过程,朋友们也可以参考. 计划如下: 用5台机器搭建,IP分别为:192.168.58.5.192.168.58.6.192.168.58.8.19 ...

  5. Windows 搭建MongoDB分片集群(二)

    在本篇博客中我们主要讲描述分片集群的搭建过程.配置分片集群主要有两个步骤,第一启动所有需要的mongod和mongos进程.第二步就是启动一个mongos与集群通信.下面我们一步步来描述集群的搭建过程 ...

  6. Windows 搭建MongoDB分片集群(一)

    一.角色说明 要构建一个MongoDB分片集群,需要三个角色: shard server  即存储实际数据得分片,每个shard 可以是一个Mongod实例,也可以是一组mongod实例构成得Repl ...

  7. MongoDB分片集群原理、搭建及测试详解

    随着技术的发展,目前数据库系统对于海量数据的存储和高效访问海量数据要求越来越高,MongoDB分片机制就是为了解决海量数据的存储和高效海量数据访问而生. MongoDB分片集群由mongos路由进程( ...

  8. [ MongoDB ] 分片集群及测试

    分片 在Mongodb里面存在另一种集群,就是分片技术,可以满足MongoDB数据量大量增长的需求. 当MongoDB存储海量的数据时,一台机器可能不足以存储数据,也可能不足以提供可接受的读写吞吐量. ...

  9. 网易云MongoDB分片集群(Sharding)服务已上线

    此文已由作者温正湖授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. MongoDB sharding cluster(分片集群)是MongoDB提供的数据在线水平扩展方案,包括 ...

随机推荐

  1. Day3--------------目录文件的浏览、管理及维护

    1.pwd命令功能 2.cd命令功能 cd..      返回上一级 cd~ cd- 返回上一次的目录 cd 3.ls命令功能 ls -a ls -all ls -l 4.cp命令功能 cp -i 覆 ...

  2. 实现Canvas2D绘图 使元素绕中心居中旋转

    我之前用canvas写了个头像剪切的demo,但是关于让载入的图片旋转是个问题,虽然通过其它方法实现了,但是感觉并不太好,于是查了些资料,想试着重新做一下canvas的旋转. 在开始之前,先让我们来做 ...

  3. 【BootStrap】 布局组件 I

    BootStrap布局组件 I 除了在原生的HTML基础上进行了外观和类别上的改进,BS还包装了很多组件进库中,设计网页时我们可以方便地调用这些组件.下面来简略地介绍一下各种各样的组件 ■ 字体图标 ...

  4. 使用idea新建jsp

    使用idea解决新建jsp文件而找不到jsp文件模版的新建选项,这样每次创建一个新的jsp文件岂不是很耗时间? 解决办法: 就是要让idea知道你需要在这个目录下创建jsp文件 左上角,file中点击 ...

  5. C语言第六周博客作业--数据类型

    一.PTA实验作业 题目1: 7-6 掉入陷阱的数字 1. 本题PTA提交列表 2.设计思路 定义变量N,i,g=1表示位数,a表示各位数字相加的和,b=0,j,N1,c,d用于储存N do{ for ...

  6. C语言指针作业

    一.PTA实验作业 题目1:6-5 判断回文字符串 1. 本题PTA提交列表 2. 设计思路 3.代码截图 4.本题调试过程碰到问题及PTA提交列表情况说明. 第一次做的时候我j直接等于count,其 ...

  7. 1013团队Beta冲刺day4

    项目进展 李明皇 今天解决的进度 因服务器端未完成登录态维护,故无法进行前后端联动. 明天安排 前后端联动调试 林翔 今天解决的进度 因上课和实验室事务未完成登录态维护 明天安排 完成登录态维护 孙敏 ...

  8. android 广播,manifest.xml注册,代码编写

    1.种 private void downloadBr(File file) {   // 广播出去,由广播接收器来处理下载完成的文件   Intent sendIntent = new Intent ...

  9. 手把手教你 LabVIEW 串口仪器控制——VISA 驱动下载安装篇

           仪器控制,核心在于 VISA 函数..有些仪器可能不需要 VISA,有自己的 DLL 什么的,我就管不着.        正常情况下,大家安装的 LabVIEW,都是不带 VISA 驱动 ...

  10. 常用的 html 标签及注意事项

    <a> 标签 用法:用于定义超链接 清除浏览器默认样式: a { text-decoration: none;/* 去除下划线 */ color: #333;/* 改变链接颜色 */ } ...