Uploaded image for project: 'Core Server'
  1. Core Server
  2. SERVER-26078

Top-chunk auto-split unnecessarily moves chunks

    • Type: Icon: Bug Bug
    • Resolution: Won't Fix
    • Priority: Icon: Major - P3 Major - P3
    • None
    • Affects Version/s: 3.0.12, 3.2.9, 3.3.12
    • Component/s: Sharding
    • Sharding
    • ALL

      The top-chunk auto-split optimization does not consult the global chunk distribution state and might cause chunks to move unnecessarily.

      Consider the case where there are 4 shards with the following assignment of chunks:

      Shard1 - 100
      Shard2 - 10
      Shard3 - 0
      Shard4 - 0
      

      If inserts are happening to a chunk on shard 2 and these trigger top-chunk auto-split with suggested move, a chunk from shard 2 will be moved off to 3 or 4, even though this is completely unnecessary given the overall distribution.

      The problem is slightly exacerbated in 3.4 with the support for parallel migrations, because there is higher chance that in this case the second migration will actually proceed, versus in prior versions where the migration will most likely fail due to the restriction of single migration per collection.

            Assignee:
            backlog-server-sharding [DO NOT USE] Backlog - Sharding Team
            Reporter:
            kaloian.manassiev@mongodb.com Kaloian Manassiev
            Votes:
            0 Vote for this issue
            Watchers:
            10 Start watching this issue

              Created:
              Updated:
              Resolved: