MongoDB   发布时间:2022-05-23  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了8天学通MongoDB——第六天 分片技术大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_618_0@     在mongodb里面存在另一种集群,就是分片技术,跟sql server的表分区类似,我们知道当数据量达到T级别的时候,我们的磁盘,内存

@H_618_0@就吃不消了,针对这样的场景我们该如何应对。

@H_618_0@一:分片

@H_618_0@     mongodb采用将集合进行拆分,然后将拆分的数据均摊到几个片上的一种解决方案。

@H_618_0@

img src="https://code.js-code.com/res/2019/02-17/00/23624d4042495944f8e02eea080af448.png" alt="">

@H_618_0@下面我对这张图解释一下:

@H_618_0@     人脸:       代表客户端,客户端肯定说,你数据库分片不分片跟我没关系,我叫你干啥就干啥,没什么好商量的。

@H_618_0@     mongos: 首先我们要了解”片键“的概念,也就是说拆分集合的依据是什么?按照什么键值进行拆分集合....

@H_618_0@                     好了,mongos就是一个路由服务器,它会根据管理员设置的“片键”将数据分摊到自己管理的mongod集群,数据

@H_618_0@                    和片的对应关系以及相应的配置信息保存在"config服务器"上。

@H_618_0@    mongod:   一个普通的数据库实例,如果不分片的话,我们会直接连上mongod。

@H_618_0@二: 实战

@H_618_0@    首先我们准备4个mongodb程序,我这里是均摊在C,D,E,F盘上,当然你也可以做多个文件夹的形式。

@H_618_0@1:开启config服务器

@H_618_0@      先前也说了,mongos要把mongod之间的配置放到config服务器里面,理所当然首先开启它,我这里就建立2222端口。

@H_618_0@

img src="https://code.js-code.com/res/2019/02-17/00/ef4eaaba3add509ed9d817bbe8d1d8f4.png" alt="">

@H_618_0@2: 开启mongos服务器

@H_618_0@    这里要注意的是我们开启的是mongos,不是mongod,同时指定下config服务器,这里我就开启D盘上的mongodb,端口3333。

@H_618_0@

img src="https://code.js-code.com/res/2019/02-17/00/8cc079c8e4bdd9fba69c7d5f5e3acc3f.png" alt="">

@H_618_0@3:启动mongod服务器

@H_618_0@     对分片来说,也就是要添加片了,这里开启EF盘的mongodb端口为:4444,5555。

@H_618_0@

img src="https://code.js-code.com/res/2019/02-17/00/ff155b86852c96314abb462de647521a.png" alt="">

@H_618_0@4: 服务配置

@H_618_0@    哈哈,是不是很兴奋,还差最后一点配置我们就可以大功告成。

@H_618_0@ <1> 先前图中也可以看到,我们clIEnt直接跟mongos打交道,也就说明我们要连接mongos服务器,然后将4444,5555的mongod@H_618_0@ @H_618_0@         交给mongos,添加分片也就是addshard()。

@H_618_0@

img src="https://code.js-code.com/res/2019/02-17/00/8ada407548c88a892a3f829f0fb2f106.png" alt="">

@H_618_0@这里要注意的是,在addshard中,我们也可以添加副本集,这样能达到更高的稳定性。

@H_618_0@<2>片已经集群了,但是mongos不知道该如何切分数据,也就是我们先前所说的片键,在mongodb中设置片键要做两步@H_618_0@ @H_618_0@        ①:开启数据库分片功能,命令很简单 enablesharding(),这里我就开启test数据库。

@H_618_0@        ②:指定集合中分片的片键,这里我就指定为person.name字段。

@H_618_0@

img src="https://code.js-code.com/res/2019/02-17/00/8395791e87028ccb3333b40572c65b02.png" alt="">

@H_618_0@5: 查看效果

@H_618_0@好了,至此我们的分片操作全部结束,接下来我们通过mongos向mongodb插入10w记录,然后通过printShardingStatus命令

@H_618_0@查看mongodb的数据分片情况。

@H_618_0@

img src="https://code.js-code.com/res/2019/02-17/00/9c2074bc5ef20e90ca631a88ada51831.png" alt="">

@H_618_0@ 这里主要看三点信息:

@H_618_0@  ① shards:     我们清楚的看到已经别分为两个片了,shard0000和shard0001。

@H_618_0@  ② databases:  这里有个partitioned字段表示是否分区,这里清楚的看到test已经分区。

@H_618_0@  ③ chunks:     这个很有意思,我们发现集合被砍成四段:

@H_618_0@                           无穷小 —— jack0,jack0 ——jack234813,jack234813——jack9999,jack9999——无穷大。

@H_618_0@                           分区情况为:3:1,从后面的 on shardXXXX也能看得出。

大佬总结

以上是大佬教程为你收集整理的8天学通MongoDB——第六天 分片技术全部内容,希望文章能够帮你解决8天学通MongoDB——第六天 分片技术所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。