8天学通MongoDB——第六天 分片技术

     在mongodb里面存在另外一种集群,就是分片技术,跟sql server的表分区相似,咱们知道当数据量达到T级别的时候,咱们的磁盘,内存sql

就吃不消了,针对这样的场景咱们该如何应对。mongodb

 

一:分片数据库

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

 

下面我对这张图解释一下:server

     人脸:       表明客户端,客户端确定说,你数据库分片不分片跟我不要紧,我叫你干啥就干啥,没什么好商量的。内存

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

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

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

    mongod:   一个普通的数据库实例,若是不分片的话,咱们会直接连上mongod。test

 

二: 实战

    首先咱们准备4个mongodb程序,我这里是均摊在C,D,E,F盘上,固然你也能够作多个文件夹的形式。

1:开启config服务器

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

 

2: 开启mongos服务器

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

 

3:启动mongod服务器

     对分片来讲,也就是要添加片了,这里开启E,F盘的mongodb,端口为:4444,5555。

 

4: 服务配置

    哈哈,是否是很兴奋,还差最后一点配置咱们就能够大功告成。

 <1> 先前图中也能够看到,咱们client直接跟mongos打交道,也就说明咱们要链接mongos服务器,而后将4444,5555的mongod

         交给mongos,添加分片也就是addshard()。

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

 

<2>片已经集群了,可是mongos不知道该如何切分数据,也就是咱们先前所说的片键,在mongodb中设置片键要作两步

        ①:开启数据库分片功能,命令很简单 enablesharding(),这里我就开启test数据库。

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

 

5: 查看效果

好了,至此咱们的分片操做所有结束,接下来咱们经过mongos向mongodb插入10w记录,而后经过printShardingStatus命令

查看mongodb的数据分片状况。

 这里主要看三点信息:

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

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

  ③ chunks:     这个颇有意思,咱们发现集合被砍成四段:

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

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

相关文章
相关标签/搜索