- Sharding >
- Sharded Cluster Tutorials >
- Sharded Cluster Data Management >
- Migrate Chunks in a Sharded Cluster
Migrate Chunks in a Sharded Cluster¶
In most circumstances, you should let the automatic balancer migrate chunks between shards. However, you may want to migrate chunks manually in a few cases:
- When pre-splitting an empty collection, migrate chunks manually to distribute them evenly across the shards. Use pre-splitting in limited situations to support bulk data ingestion.
- If the balancer in an active cluster cannot distribute chunks within the balancing window, then you will have to migrate chunks manually.
To manually migrate chunks, use the moveChunk command.
For more information on how the automatic balancer moves chunks
between shards, see Cluster Balancer and
Chunk Migration.
Example
Migrate a single chunk
The following example assumes that the field username is the
shard key for a collection named users in the myapp
database, and that the value smith exists within the chunk
to migrate. Migrate the chunk using the following command in the
mongo shell.
This command moves the chunk that includes the shard key value “smith” to the
shard named mongodb-shard3.example.net. The command will
block until the migration is complete.
Tip
To return a list of shards, use the listShards
command.
Example
Evenly migrate chunks
To evenly migrate chunks for the myapp.users collection,
put each prefix chunk on the next shard from the other and run
the following commands in the mongo shell:
See Create Chunks in a Sharded Cluster for an introduction to pre-splitting.
New in version 2.2: The moveChunk command has the: _secondaryThrottle
parameter. When set to true, MongoDB ensures that changes to
shards as part of chunk migrations replicate to secondaries throughout the migration operation. For more
information, see Require Replication During Chunk Migration (Secondary Throttle).
Changed in version 2.4: In 2.4, _secondaryThrottle is true by default.