首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在数据库级别实现Mongodb分片,不对集合进行分片

在数据库级别实现Mongodb分片,不对集合进行分片
EN

Stack Overflow用户
提问于 2012-08-31 01:38:05
回答 1查看 1.9K关注 0票数 2

我正在尝试在我们的mongoDB数据库上实现分片,这是一个场景

我们有一台运行配置服务器的服务器

我们有两台服务器运行名为node1和node2的mongod实例

我们有一台运行mongos的服务器

我已经使用以下命令在mongos shell中添加了服务器node1和node2作为分片服务器

db.runCommand( { addshard:“服务器主机名:端口”} );

后来,我在node1中创建了数据库,并在Mongos中为该数据库启用了分片

现在我们有了2个分片服务器,根据MongoDB文档,mongos应该在节点2上放置一些创建的node1集合(数据库实际驻留的地方)和一些集合。

我从mongos创建了300个集合,但是所有的集合仍然只有一个服务器,这在上面提到的支持中是错误的

注意:-由于我不在一个位置上升级的应用层,我不能碎片在收集层,我有一个脚本,动态创建几个集合的一些要求。

请提供您的建议,我们如何在数据库级别的分片,以便收集均匀分布在所有分片服务器。

我正在寻找一些解决方案,比如

如果我自动创建300个集合,那么mongos应该会在两个分片的服务器上创建大约150或100个集合。

提前感谢你介入并帮助我解决这个问题。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-08-31 01:46:13

在对集合执行enable sharding操作并添加数据之前,集合不会自动跨分片分布。然后,这些分片的集合将在两个分片上都有数据(拆分成块并自动平衡)。

直到您在集合上实际运行该命令,并且其中有足够的数据,以便它们开始拆分和迁移块,然后它们都将留在原来的位置。

这是因为每个数据库都有一个不变的主分片。这是最初创建数据库的位置,也是所有非分片数据的存储位置。如果您添加了另一个数据库,mongos应该在第二个分片上创建它,并为每个创建的数据库创建备用数据库(如果超过两个,则为循环)。在每种情况下,在您对集合进行分片之前,它将仅保留在该数据库的主分片上。

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

https://stackoverflow.com/questions/12202474

复制
相关文章

相似问题

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