Definition
sh.moveChunk(namespace, query, destination)Moves the chunk that contains the document specified by the
queryto thedestinationshard.sh.moveChunk()provides a wrapper around themoveChunkdatabase command.Important
In most circumstances, allow the balancer to automatically migrate chunks, and avoid calling
sh.moveChunk()directly.Important
mongo Shell Method
This page documents a
mongomethod. This is not the documentation for database commands or language-specific drivers, such as Node.js. To use the database command, see themoveChunkcommand.For MongoDB API drivers, refer to the language-specific MongoDB driver documentation.
sh.moveChunk()takes the following arguments:ParameterTypeDescriptionnamespacestring
The namespace of the sharded collection that contains the chunk to migrate.
querydocument
An equality match on the shard key that selects the chunk to move.
destinationstring
The name of the shard to move.
By default, MongoDB cannot move a chunk if the number of documents in the chunk is greater than 1.3 times the result of dividing the configured chunk size by the average document size. Starting in MongoDB 4.4, the
moveChunkcommand can specify a new option forceJumbo to allow for the manual migration of chunks too large to move, with or without the jumbo label. See moveChunk command for details.
Example
Given the people collection in the records database, the
following operation finds the chunk that contains the documents with the
zipcode field set to 53187 and then moves that chunk to the
shard named shard0019:
sh.moveChunk("records.people", { zipcode: "53187" }, "shard0019")