共计 1471 个字符,预计需要花费 4 分钟才能阅读完成。
这篇文章主要为大家展示了“mongodb 分片技术的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让丸趣 TV 小编带领大家一起研究并学习一下“mongodb 分片技术的示例分析”这篇文章吧。
在 mongodb 里面存在另一种集群,就是分片技术,当数据量达到 T 级别的时候,我们的磁盘,内存就吃不消了,针对这样的场景我们该如何应对。
一:分片
mongodb 采用将集合进行拆分,然后将拆分的数据均摊到几个片上的一种解决方案。
下面我对这张图解释一下:
人脸:代表客户端,客户端肯定说,你数据库分片不分片跟我没关系,我叫你干啥就干啥,没什么好商量的。
mongos: 首先我们要了解”片键“的概念,也就是说拆分集合的依据是什么?按照什么键值进行拆分集合 ….
好了,mongos 就是一个路由服务器,它会根据管理员设置的“片键”将数据分摊到自己管理的 mongod 集群,数据
分片的对应关系以及相应的配置信息保存在 config 服务器 上。
mongod: 一个普通的数据库实例,如果不分片的话,我们会直接连上 mongod。
二: 实战
首先我们准备 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 也能看得出。
以上是“mongodb 分片技术的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道!