练习 MongoDB 操作 —— 分片篇(五)

news/2024/7/2 23:02:12

分片(sharding)是指将数据拆分,将其分散存在不同的机器上的过程。在关系型数据库中,当一个表太大(超过几亿行数据)时,我们也有分表的做法,和这里的分片是类似的概念。

术语

  • “片”:一个独立的MongoDB服务(即mongod服务进程,在开发测试环境中)或一个副本集(在生产环境中)。
  • “片键”:在路由服务器上设置分片时,需要从开启分片的集合中选取一个键,用该键作为数据存放在哪个片的依据。这个键就称为“片键”。对于选择哪个键作为片键?有个原则就是,片键应该有较多变化的值。
  • “配置服务器”:一个mongod服务进程,但这个数据库服务仅仅是为mongos路由服务提供配置信息存储的位置!启动mongos服务时,需要提供一个mongod服务器,以便路由服务访问或存储相关的配置信息。配置信息主要包括:分片与数据的对应关系!(配置服务器必须开启1个或则3个,开启2个则会报错(
  • mongos”服务:MongoDB自带的路由服务进程,它路由所有的客户端请求,并将各个片的结果进行汇聚返回。这个服务进程本身不会存储任何数据或配置信息(有时会缓存配置服务器的相关配置信息)。

示例

环境搭建

启动两台mongodb服务器(2701727018),一台配置服务器(27019)和一个路由服务(27020);

注意: Mongodb3.4版本开始要求配置服务器要是复制集

// 启动分片服务器,注意要加 --shardsvr
./bin/mongod --dbpath shard1/data --logpath shard1/log/0924.log --fork --port 27017 --shardsvr
./bin/mongod --dbpath shard2/data --logpath shard2/log/0924.log --fork --port 27018 --shardsvr// 配置服务器, 注意要加 --configsvr
./bin/mongod --dbpath shard_router_server/data --logpath shard_router_server/log/0924.log --fork --port 27019 --configsvr --replSet config// 启动路由服务
./bin/mongos --port 27020 --configdb config/localhost:27019 --logpath shard_router/log/0924.log --fork

进入路由服务,注册参与分片的节点

mongos> use admin
mongos> db.runCommand({"addshard" : "192.168.1.168:27017"});
mongos> db.runCommand({"addshard" : "192.168.1.168:27018"});

查看分片信息

mongos> sh.status()

查看分片成员

mongos> db.runCommand({listshards: 1})
// 或切换到 config 数据库,查看 shards 集合
mongos> use config
mongos> db.shards.find()

删除分片

mongos> db.runCommand({"removeshard":"192.168.1.168:27017"})

此时后台会自动开启分片数据库的数据迁移;然后需要手动迁移未开启分片数据库的数据;

手动迁移命令,可以参考

mongos> db.runCommand({ movePrimary: "school", to: "192.168.1.168:27018" })

开启分片

如果对应的数据库没有开启分片功能,则通过路由服务新增数据,是会报错的;

笔者开启school数据库的分片功能;

mongos> db.runCommand({"enablesharding" : "school"});
// 或
mongos> sh.enableSharding("school")

那么,如果 school 数据库下的集合没有开启分片功能,那么所有对school数据库下集合的操作都会在school数据库所在的分片上执行;

查看已经在片系统上的数据库列表:

mongos> db.databases.find()

集合开启分片
school数据库下的demo集合开启分片功能;

mongos> sh.shardCollection("school.demo", {"name":1})

开启分片的集合,是以 chunks(块) 为单位;块(chunk)是由多个doc组成的一个分组,在某个索引字段(片键)上是连续的,每个chunk的片键是有一定范围的。块的默认大小是 64 MB。有些chunk会非常大,包含的doc数量非常多,但是,在MongoDB看来,仍然是一个chunk,和没有任何doc的空chunk没有区别。均衡分发保证每个shardchunk数量是大致相同的。因此,片键的选择直接影响分片的好坏。

测试分片效果

因为chunk默认大小是 64 MB(取值范围是 1 MB 到 1024 MB), 不方便查看效果(chunk数目差异较大时的拆分与平衡);

修改chunk块的大小:

mongos> use config
mongos> db.settings.save( { _id:"chunksize", value: 1 } )

此时批量向school数据库下的 demo插入 60W 条数据

mongos> use school
mongos> for(i=0;i<600000;i++){ db.demo.insert({"uid":i,"name":"zhanjindong"+i,"age":13,"data":new Date()}); }

通过命令sh.status(),可以实时查看各片上的chunk数目多少;

附录

参考阅读

  • 悦光阴的博客
  • DrifterJ's Stash的博客

http://lihuaxi.xjx100.cn/news/278449.html

相关文章

每30秒学会一个Python小技巧,GitHub星数4600+

&#xff08;图片付费下载自视觉中国&#xff09;作者 | xiaoyu&#xff0c;数据爱好者来源 | Python数据科学&#xff08;ID:PyDataScience&#xff09;很多学习Python的朋友在项目实战中会遇到不少功能实现上的问题&#xff0c;有些问题并不是很难的问题&#xff0c;或者已经…

XSD 空元素概述

空的复合元素不能包含内容&#xff0c;只能含有属性。 复合空元素 一个空的 XML 元素&#xff1a; <product prodid"1345" />上面的 "product" 元素根本没有内容。为了定义无内容的类型&#xff0c;我们就必须声明一个在其内容中只能包含元素的类型…

使用Apache cxf 和Spring在Tomcat下发布Webservice指南

转载 http://blog.csdn.net/zhangzhaokun/article/details/4750021 最近学习了如何使用apache cxf和Spring发布webservice&#xff0c;虽然网上的资料很多&#xff0c;但是没有一个文档可以让读者按照操作步骤来实现完整的发布流程&#xff0c;都需要多篇文件杂合在一起&#x…

再加力度!浙江抢人!博士补120万,硕士补70万,本科补20万

点上方蓝字视学算法获取更多干货在右上方 设为星标 ★&#xff0c;与你不见不散仅作学术分享&#xff0c;不代表本公众号立场&#xff0c;侵权联系删除转载于&#xff1a;本文来源&#xff1a;金华日报 募格学术作者 | 王卫英 金旻博士购房一次性补贴80万元&#xff08;缴…

jmeter csv参数化_运用Jmeter参数化来实现接口自动化测试

本文记录如何使用Jmeter参数化&#xff08;csv)实现接口自动化——测试Token不同入参情况下&#xff0c;接口请求能够返回正确的结果1. 首先需要使用Jmeter获取一个Token&#xff0c;如何获取暂略&#xff08;同一般访问请求方式一样&#xff09;2. 在Jmeter中添加以下元件&…

一文了解点云及处理方法

点击上方“小白学视觉”&#xff0c;选择加"星标"或“置顶”重磅干货&#xff0c;第一时间送达本文转自&#xff1a;新机器视觉点云概念点云与三维图像的关系&#xff1a;三维图像是一种特殊的信息表达形式&#xff0c;其特征是表达的空间中三个维度的数据&#xff0…

Spring Boot + Vue + Shiro 实现前后端分离、权限控制

点击上方“方志朋”&#xff0c;选择“设为星标”回复”666“获取新整理的面试资料来源&#xff1a;http://sina.lt/gauR本文总结自实习中对项目的重构。原先项目采用Springbootfreemarker模版&#xff0c;开发过程中觉得前端逻辑写的实在恶心&#xff0c;后端Controller层还必…

XSD 复合元素概述

复合元素包含了其他的元素及/或属性。 什么是复合元素&#xff1f; 复合元素指包含其他元素及/或属性的 XML 元素。 有四种类型的复合元素&#xff1a; 空元素包含其他元素的元素仅包含文本的元素包含元素和文本的元素 注意&#xff1a; 上述元素均可包含属性&#xff01; …