天天看点

八天学会MongoDB:第六天 分片技术

  <b>一:分片</b>

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

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

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

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

 <b> 二: 实战</b>

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

 <b> 1:开启config服务器</b>

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

 <b> 2: 开启mongos服务器</b>

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

 <b> 3:启动mongod服务器</b>

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

  <b>4: 服务配置</b>

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

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

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

  &lt;2&gt;片已经集群了,但是mongos不知道该如何切分数据,也就是我们先前所说的片键,在mongodb中设置片键要做两步

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

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

  <b>5: 查看效果</b>

  好了,至此我们的分片操作全部结束,接下来我们通过mongos向mongodb插入10w记录,然后通过printShardingStatus命令查看mongodb的数据分片情况。

  这里主要看三点信息:

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

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

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

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

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

本文转自 wws5201985 51CTO博客,原文链接:http://blog.51cto.com/wws5201985/818582,如需转载请自行联系原作者