MongoDB chunk too big to move的解決方案

chenfeng發表於2016-05-30
當某些塊中的資料量特別大, 形成特大塊的時候, Balancer就無法對資料塊進行拆分, 也就無法對塊進行挪動。使用MongDB 3.2版本, 解決方案如下:

C:\Users\duansf>mongo
MongoDB shell version: 2.6.6
connecting to: test

1).首先關閉Balancer
mongos>sh.stopBalancer()

2).查詢特大塊
mongos>use config
mongos>db.chunks.find({jumbo:true})

3).拆分特大塊
mongos>sh.splitAt("db.collection", {shardkye:"拆分的臨界值"})

4).手動挪動塊(可選步驟)
mongos>sh.moveChunk("db.collection", {shardkey:"shardkey所在的塊"}, "需要移動的目標分片ID");

5).重啟Balancer
mongos>sh.startBalancer()

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15498/viewspace-2109384/,如需轉載,請註明出處,否則將追究法律責任。

相關文章