迁移分片请求
迁移数据库分片的 REST API 请求
Redis 企业软件 |
---|
方法 | 路径 | 描述 |
---|---|---|
发布 | /v1/shards/actions/migrate |
迁移多个分片 |
发布 | /v1/shards/{uid}/actions/migrate |
迁移特定分片 |
迁移多个分片
POST /v1/shards/actions/migrate
将给定分片 UID 的列表迁移到target_node_uid
.分片可以来自多个数据库。此请求是异步的。
有关分片迁移使用案例和注意事项的更多信息,请参阅迁移数据库分片。
所需权限
权限名称 | 角色 |
---|---|
migrate_shard | admin cluster_member db_member |
请求
HTTP 请求示例
POST /v1/shards/actions/migrate
示例 JSON 正文
{
"shard_uids": ["2","4","6"],
"target_node_uid": 9,
"override_rack_policy": false,
"preserve_roles": false,
"max_concurrent_bdb_migrations": 3
}
Request headers
Key
Value
Description
Host
cnm.cluster.fqdn
Domain name
Accept
application/json
Accepted media type
Request body
The request body is a JSON object that can contain the following fields:
Field
Type
Description
shard_uids
array of strings
List of shard UIDs to migrate.
target_node_uid
integer
UID of the node to where the shards should migrate.
override_rack_policy
boolean
If true, overrides and ignores rack-aware policy violations.
dry_run
boolean
Determines whether the migration is actually done. If true, will just do a dry run. If the dry run succeeds, the request returns a 200 OK
status code. Otherwise, it returns a JSON object with an error code and description.
preserve_roles
boolean
If true, preserves the migrated shards' roles after migration.
max_concurrent_bdb_migrations
integer
The number of concurrent databases that can migrate shards.
Response
Returns a JSON object with an action_uid
. You can track the action's progress with a GET /v1/actions/<action_uid>
request.
Example JSON body
{
"action_uid": "e5e24ddf-a456-4a7e-ad53-4463cd44880e",
"description": "Migrate was triggered"
}
Status codes
Code
Description
200 OK
No error.
400 Bad Request
Conflicting parameters.
404 Not Found
A list of shard UIDs is required and not given, a specified shard does not exist, or a node UID is required and not given.
500 Internal Server Error
Migration failed.
Migrate shard
POST /v1/shards/{int: uid}/actions/migrate
Migrates the shard with the given shard_uid
to the node specified by target_node_uid
. If the shard is already on the target node, nothing happens. This request is asynchronous.
For more information about shard migration use cases and considerations, see Migrate database shards.
Required permissions
Permission name
Roles
migrate_shard
admin
cluster_member
db_member
Request
Example HTTP request
POST /v1/shards/1/actions/migrate
Example JSON body
{
"target_node_uid": 9,
"override_rack_policy": false,
"preserve_roles": false
}
Request headers
Key
Value
Description
Host
cnm.cluster.fqdn
Domain name
Accept
application/json
Accepted media type
URL parameters
Field
Type
Description
uid
integer
The unique ID of the shard to migrate.
Request body
The request body is a JSON object that can contain the following fields:
Field
Type
Description
target_node_uid
integer
UID of the node to where the shard should migrate.
override_rack_policy
boolean
If true, overrides and ignores rack-aware policy violations.
dry_run
boolean
Determines whether the migration is actually done. If true, will just do a dry run. If the dry run succeeds, the request returns a 200 OK
status code. Otherwise, it returns a JSON object with an error code and description.
preserve_roles
boolean
If true, preserves the migrated shards' roles after migration.
Response
Returns a JSON object with an action_uid
. You can track the action's progress with a GET /v1/actions/<action_uid>
request.
Example JSON body
{
"action_uid": "e5e24ddf-a456-4a7e-ad53-4463cd44880e",
"description": "Migrate was triggered"
}
Status codes
Code
Description
200 OK
No error.
404 Not Found
Shard does not exist, or node UID is required and not given.
409 Conflict
Database is currently busy.
On this page