在数据库级别实现Mongodb分片并保持集合不受影响

时间:2012-08-30 17:38:05

标签: mongodb sharding

我正在尝试在我们的mongoDB数据库上实现分片,这是方案

我们有1个运行配置服务器的服务器

我们有2个运行mongod实例的服务器,名为node1和node2

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

我已使用命令

将服务器node1和node2添加为mongos shell中的分片服务器

db.runCommand({addshard:“serverhostname [:port]”});

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

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

我从mongos创建了300个集合,但是仍然所有集合只向一个服务器发送了上述支持中的错误

注意: - 由于我无法升级应用程序层,因此我无法在集合级别进行分片,因此我有一个脚本可以根据某些需求动态创建多个集合。

请提供有关我们如何在数据库级别进行分片的建议,以便集合在所有分片服务器之间平均分配。

我正在寻找像

这样的解决方案

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

提前感谢您介入并帮助我解决此问题。

1 个答案:

答案 0 :(得分:2)

在您对enable sharding上添加数据之前,集合不会自动分布在整个分片中。那些分片集合将在两个分片上都有数据(分成块并自动平衡)。

在你真正对集合运行命令并在其中包含足够的数据以便它们开始拆分和迁移块之前,它们都将保持原样。

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