moveChunk
定义
moveChunk
内部管理命令。 在 分片 之间 移动 数据段。使用 管理员数据库
moveChunk
mongos
时,通过 实例发出 命令。使用以下形式:提示
在
mongosh
中,该命令也可通过sh.moveChunk()
辅助方法运行。辅助方法对
mongosh
用户来说很方便,但它们返回的信息级别可能与数据库命令不同。如果不追求方便或需要额外的返回字段,请使用数据库命令。db.adminCommand( { moveChunk : <namespace> , find : <query> , to : <string>, forceJumbo: <boolean>, _secondaryThrottle : <boolean>, writeConcern: <document>, _waitForDelete : <boolean> } ) 或者:
db.adminCommand( { moveChunk : <namespace> , bounds : <array> , to : <string>, forceJumbo: <boolean>, _secondaryThrottle : <boolean>, writeConcern: <document>, _waitForDelete : <boolean> } ) moveChunk
命令拥有以下字段:字段类型说明moveChunk
字符串find
文档bounds
阵列要移动的特定数据块的边界。该数组必须由两个文档组成,这两个文档指定要移动的数据段的下分片键值和上分片键值。 指定bounds
字段或find
字段,但不能同时指定两者。 使用bounds
选择使用哈希分片键的collection中的数据块。to
字符串数据段的目标分片的名称。布尔可选。 一个标志,用于确定该命令是否可以移动过大而无法迁移的数据块。该数据段可能会也可能不会标记为jumbo。
如果为
true
,则该命令可以移动数据块。如果为
false
,则该命令无法移动数据块。
默认为
false
。警告:
带有
forceJumbo=true
的moveChunk
命令会阻止对集合的读取和写入操作。此选项会导致分片迁移数据段,即使数据段大于配置的数据段大小。 该集合在迁移期间保持不可用状态。
要在没有这么长的阻塞期的情况下迁移这些大数据段,请参阅平衡超出大小限制的范围。
_secondaryThrottle
布尔可选。 对于WiredTiger ,默认为
false
。如果
true
,则默认情况下,数据段迁移期间的每个文档移动都会传播到至少一个从节点,然后负载均衡器才会继续处理下一个文档。 这相当于 写关注(write{ w: 2 }
concern)的。使用
writeConcern
选项指定不同的写关注(write concern)。如果为
false
,负载均衡器不会等待复制到从节点,而是继续处理下一个文档。
有关更多信息,请参阅辅助限制。
writeConcern
文档可选。 一个表达写关注(write concern)的文档,在数据块迁移期间,
_secondaryThrottle
将使用该写关注(write concern)来等待从节点。writeConcern
需要_secondaryThrottle: true
。_waitForDelete
布尔bounds
的值采用以下形式:[ { hashedField : <minValue> } , { hashedField : <maxValue> } ] 数据块迁移部分描述了数据块如何在 MongoDB 上的分片之间移动。
兼容性
此命令可用于以下环境中托管的部署:
MongoDB Atlas:用于云中 MongoDB 部署的完全托管服务
重要
无服务器实例不支持此命令。 有关更多信息,请参阅不支持的命令。
MongoDB Enterprise:基于订阅、自我管理的 MongoDB 版本
MongoDB Community:源代码可用、免费使用且可自行管理的 MongoDB 版本
Considerations
仅在特殊情况下使用moveChunk
,例如为初始数据摄取或大批量导入操作准备分片集群。 在大多数情况下,允许负载均衡器在分片集群中创建和均衡数据段。 有关更多信息,请参阅在分片集群中创建范围。
行为
索引
moveChunk
要求所有索引都存在于目标上(即 to
)分片,如果所需的索引不存在,则返回错误。
元数据错误
moveChunk
如果正在对chunks
集合执行另一个元数据操作, 将返回以下错误消息:
errmsg: "The collection's metadata lock is already taken."
如果另一个进程(例如负载均衡器进程)在moveChunk
运行时更改元数据,则可能会看到此错误。 您可以重试moveChunk
操作,不会产生副作用。
maxCatchUpPercentageBeforeBlockingWrites
服务器参数
从 MongoDB 5.0开始,您可以设置maxCatchUpPercentageBeforeBlockingWrites
,以指定在moveChunk
操作期间,与正在传输的数据段总大小(以 MB 为单位)相比,尚未迁移的数据的最大允许百分比。