1

我尝试在 MongoDB 中测试分片。例如,我使用 host1.com 和 host2.com 代替真实的服务器名称。

所以我在 host1.com 创建了配置服务器:

mongod --dbpath /path/to/configdb/ --configsvr

mongos在同一台机器上启动:

mongos --configdb host1.com --port 27020

并从mongod两台机器(host1.com 和 host2.com)开始:

mongod --dbpath /path/to/test_shard_db/ --shardsvr

我添加了分片,使用分片键 {'name': 1} 为数据库test和集合启用分片test(集合只有此字段并_id用于测试),如教程中所述。但在所有这些操作之后,我的所有数据都只写入一个分片,这是数据库的主要分片。

这是配置:

分片状态:

mongos> db.printShardingStatus()
--- Sharding Status --- 
  sharding version: { "_id" : 1, "version" : 3 }
  shards:
    {  "_id" : "shard0000",  "host" : "host1.com:27018",  "maxSize" : NumberLong(1) }
    {  "_id" : "shard0001",  "host" : "host2.com:27018",  "maxSize" : NumberLong(10) }
  databases:
        ...
    {  "_id" : "test",  "partitioned" : true,  "primary" : "shard0000" }
        test.test chunks:
                shard0001   1
            { "name" : { $minKey : 1 } } -->> { "name" : { $maxKey : 1 } } on : shard0001 Timestamp(1000, 0)

收藏统计:

mongos> db.printCollectionStats()
test
{
    "sharded" : false,
    "primary" : "shard0000",
    "size" : 203535788,
    ...
}

平衡器状态:

mongos> sh.isBalancerRunning()
true

那么,为什么我添加了超过 1 兆字节的数据,但集合中的所有数据都只驻留在一个分片中呢?为什么要给db.printCollectionStats()我看那个test数据库"sharded" : false。我做错了什么?

4

1 回答 1

3

默认块大小为 64MB,因此在发生拆分之前您有增长空间。您可以事先自己拆分分片键范围,这可以让写入从一开始就进入多个分片。有关更多信息,请参阅MongoDB 拆分块文档

关于 chunk size 和 maxSize 的区别:

maxSize 将限制给定分片上的数据量。当达到时,平衡器将寻找将块移动到未达到 maxSize 的分片。块是文档的集合,它们都属于分片键范围的一部分。MongoDB 平衡器将在块级别在分片之间移动数据以进行平衡。当一个块接近 maxSize 值时,它将被分成 2 个,这可能会导致移动。

于 2013-04-04T15:06:24.607 回答