首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何分割数据?

如何分割数据?
EN

Stack Overflow用户
提问于 2016-09-28 10:28:15
回答 1查看 162关注 0票数 2

为了提供写扩展,我决定将独立的mongoDB转换为分片集群。问题是,我无法找到具有高度随机性的切分键,以确保集群的写操作分布均匀,而且,只要所有集合都有复合唯一索引,就不能使用散列碎片键。

我认为有两种解决办法:

  1. 使用唯一索引的前缀作为切分键。但是,即使忽略了糟糕的分配,这也是不可接受的原因,因为不知何故,所有的块都放在主碎片上,然后平衡器将它们分布在碎片之间。当我使用散列切分时,把负数放在第一个切分上,正数放在第二个碎片上。如何使用范围分布强制mongoDB在两个碎片之间分配块?
  2. 若要使用标记感知切分,请执行以下操作。但是我无法预测未来几个月的数据,所以我的标签在未来的分布可能是不均匀的。我认为自动化数据标记没有廉价的解决方案。

您知道使用复合唯一键的集合的切分解决方案吗?

EN

回答 1

Stack Overflow用户

发布于 2017-06-14 20:22:10

您可以使用UUID (通用唯一标识符)

https://docs.mongodb.com/manual/reference/method/UUID/

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39744862

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档