重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
就是超出设定的chunk大小的chunk,默认chunk大小为64M
创新互联,为您提供重庆网站建设、成都网站制作、网站营销推广、网站开发设计,对服务成都PE包装袋等多个行业拥有丰富的网站建设及推广经验。创新互联网站建设公司成立于2013年,提供专业网站制作报价服务,我们深知市场的竞争激烈,认真对待每位客户,为客户提供赏心悦目的作品。 与客户共同发展进步,是我们永远的责任!
jumbo chunk无法被迁移
# 先找到Jumbo chunk信息
sh.status(true)
{ "phone" : NumberLong("xxxxxx") } -->> { "phone" : NumberLong("yyyyyyy") } on : shard_rep1 Timestamp(1, 19) jumbo
# 执行
# 对于上面的Jumbo块,执行如下命令
sh.splitFind("db.tb",{shardkeyX:"shardkeyXValue_in_range"})
db = db.getSiblingDB('config');
var goblins=db.chunks.find({"jumbo":true})
goblins.forEach( function (item) {
databaseDotTable = item.ns;
minShardKeyInfo = item.min;
maxShardKeyInfo = item.max
for (var i in minShardKeyInfo) {
var key=i;
var value=minShardKeyInfo[i];
if (typeof(value) === "function") {
for (var j in maxShardKeyInfo) {
value = maxShardKeyInfo[j]
}
}
}
var findFilter = {}
findFilter[key] = value
print(`Doing db.adminCommand({"${databaseDotTable}",{${key}:${value}})}`);
result=db.adminCommand({split:databaseDotTable,find:findFilter});
printjson(result)
})
1.官方推荐使用更加自动的sh.splitFind
而不是原始的sh.splitAt
函数