移动对象
功能说明
移动对象或按对象名前缀批量移动对象。

- 移动对象时,请确保OBS桶中的源对象不发生变化,否则可能产生移动失败或者数据不一致的问题。
- 如果被移动对象的存储类型为cold,必须首先恢复被移动对象,否则无法移动成功。
- 移动对象或批量移动成功后,源端对象会被删除。
- 当使用 OBS Util 执行对象移动(mv)操作时,如果该任务被主动取消或遭遇意外中断,工具本身无法自动恢复或继续执行。请注意,这种情况可能导致移动操作未能完整执行(例如,已完成复制但未删除源),从而造成源对象和目标对象同时存在。
- 如果源桶是并行文件系统(POSIX),则目标桶不能是对象存储桶。
命令结构
- Windows操作系统
- 移动单个对象
obsutil mv obs://srcbucket/key obs://dstbucket/[dest] [-dryRun] [-u] [-p=1] [-threshold=52428800] [-versionId=xxx] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-ps=auto] [-cpd=xxx] [-fr] [-o=xxx] [-config=xxx] [-e=xxx] [-i=xxx] [-k=xxx] [-t=xxx]
- 批量移动对象
obsutil mv obs://srcbucket[/key] obs://dstbucket[/dest] -r [-dryRun] [-f] [-flat] [-u] [-j=1] [-p=1] [-threshold=52428800] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-ps=auto] [-include=*.xxx] [-exclude=*.xxx] [-timeRange=time1-time2] [-mf] [-o=xxx] [-cpd=xxx] [-config=xxx] [-e=xxx] [-i=xxx] [-k=xxx] [-t=xxx]
- 移动单个对象
- macOS/Linux操作系统
- 移动单个对象
./obsutil mv obs://srcbucket/key obs://dstbucket/[dest] [-dryRun] [-u] [-p=1] [-threshold=52428800] [-versionId=xxx] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-ps=auto] [-cpd=xxx] [-fr] [-o=xxx] [-config=xxx] [-e=xxx] [-i=xxx] [-k=xxx] [-t=xxx]
- 批量移动对象
./obsutil mv obs://srcbucket[/key] obs://dstbucket[/dest] -r [-dryRun] [-f] [-flat] [-u] [-j=1] [-p=1] [-threshold=52428800] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-ps=auto] [-include=*.xxx] [-exclude=*.xxx] [-timeRange=time1-time2] [-mf] [-o=xxx] [-cpd=xxx] [-config=xxx] [-e=xxx] [-i=xxx] [-k=xxx] [-t=xxx]
- 移动单个对象

- 移动的源路径和目标路径不能完全相同。
- 批量移动时,源路径和目标路径不能相互嵌套。
- 不支持对并行文件系统的批量移动的操作。
运行示例
- 以Windows操作系统为例,运行obsutil mv obs://bucket-test/key obs://bucket-test2 ,移动单个对象。
obsutil mv obs://bucket-test/key obs://bucket-test2 Start at 2024-09-30 08:36:01.3934921 +0000 UTC Parallel: 5 Jobs: 5 Threshold: 50.00MB PartSize: auto CheckpointDir: xxxx [=====================================================] 100.00% 6/s 0s Waiting for the copied key to be completed on server side. Move successfully, 19B, obs://bucket-test/key --> obs://bucket-test2/key, cost [1815], status [200], request id [00000192421282AC401423183A8B83A1]
- 以Windows操作系统为例,运行obsutil mv obs://bucket-test/temp/ obs://bucket-test2 -f -r,批量移动对象。
obsutil mv obs://bucket-test/temp/ obs://bucket-test2 -f -r Start at 2024-09-30 08:37:32.2454905 +0000 UTC Parallel: 5 Jobs: 5 Threshold: 50.00MB PartSize: auto CheckpointDir: xxxx Task id: 0476929d-9d23-4dc5-b2f8-0a0493f027c5 OutputDir: xxxx [=============================================================] 100.00% 10/s 0s Succeed count: 5 Failed count: 0 Metrics [max cost:298 ms, min cost:192 ms, average cost:238.00 ms, average tps:9.71, transferred size: 7.20MB] Task id: 0476929d-9d23-4dc5-b2f8-0a0493f027c5
参数说明
参数 | 约束 | 描述 |
|---|---|---|
srcbucket | 必选 | 源桶名。 |
dstbucket | 必选 | 目标桶名。 |
dest | 可选 | 移动对象时的目标对象名,或批量移动时目标对象名前缀。 |
key | 移动对象时必选 批量移动时可选 | 移动对象时的源对象名,或批量移动时源对象名前缀。 规则如下:
说明:
|
fr | 附加参数,移动对象时可选 | 移动对象时生成结果清单文件。 |
flat | 附加参数,批量移动时可选 | 移动时,不包含上一级父对象名前缀。 |
dryRun | 附加参数,可选 | 测试模式运行,不执行实际的移动操作。 |
u | 附加参数,可选 | 增量移动操作,设置该参数后,移动每个源对象时会对比目标桶中对应路径的目标对象,仅在目标对象不存在,或者目标对象大小与源对象大小不一致,或者目标对象的最后修改时间早于源对象的最后修改时间时进行移动。 说明: 如果目标对象与源对象大小以及修改时间都一致,此时会直接删除源对象,而不进行移动操作。 |
p | 附加参数,可选 | 每个分段移动任务的最大并发数,默认为配置文件中的defaultParallels。 |
threshold | 附加参数,可选 | 开启分段移动任务的阈值,单位:字节,默认为配置文件中的defaultBigfileThreshold。 说明:
|
versionId | 附加参数,移动对象时可选 | 移动单个对象时可指定的源对象版本号。 说明: POSIX桶无version概念,故POSIX桶不支持versionId选项。 |
acl | 附加参数,可选 | 移动对象时可指定的目标对象的预定义访问策略。支持的值:
说明: 以上四个值分别对应:私有读写、公共读、公共读写、桶拥有者完全控制,四种预定义访问策略。 |
sc | 附加参数,可选 | 移动对象时可指定的目标对象的存储类型。支持的值:
|
meta | 附加参数,可选 | 移动对象时可指定的目标对象的自定义元数据。格式为:key1:value1#key2:value2#key3:value3。 说明: 以上值表示移动对象完成后,桶内目标对象包含三组自定义元数据,分别为:key1:value1、key2:value2、key3:value3。 |
fs | 附加参数,可选 | 是否使用并行文件系统的列举方式,如果桶是并行文件系统,推荐加上该参数。 注意:
|
ps | 附加参数,可选 | 每个分段移动任务的段大小,单位:字节,取值范围是100KB~5GB,默认为配置文件中的defaultPartSize。 说明:
|
cpd | 附加参数,可选 | 生成断点记录文件的文件夹,默认为运行obsutil命令的用户目录的子文件夹.obsutil_checkpoint。 说明: 每个分段移动任务会产生唯一对应的断点记录文件并保存至该文件夹的copy子文件夹下,分段任务执行成功后,对应的断点记录文件会被自动删除;分段任务执行失败或被中断后,下次执行该分段任务时会尝试通过对应的断点记录文件恢复任务。 |
r | 附加参数,批量移动时必选 | 按指定源桶的对象名前缀批量移动对象。 |
f | 附加参数,批量移动时可选 | 强制操作,不进行询问提示。 |
j | 附加参数,批量移动时可选 | 批量移动时的最大并发数,默认为配置文件中的defaultJobs。 说明: 工具会保证该值至少为1。 |
exclude | 附加参数,批量移动时可选 | 不包含源对象的匹配模式,如:*.txt。 说明:
须知:
|
include | 附加参数,批量移动时可选 | 包含源对象的匹配模式,如:*.jpg。 说明:
须知:
|
timeRange | 附加参数,批量移动时可选 | 移动对象时的时间段匹配模式,仅移动最后修改时间在该时间段内的对象。 该匹配模式优先级低于对象名匹配模式:exclude和include,优先执行对象名匹配模式后才会执行该匹配模式。 说明:
须知:
|
mf | 附加参数,可选 | 设置名称匹配模式(include、exclude)和时间匹配模式(timeRange)对对象名以“/”结尾的对象也生效。 |
o | 附加参数,可选 | 生成结果清单文件的文件夹,命令执行完成后,会在该文件夹下生成结果清单文件(可能包含成功结果、失败结果和警告结果三个文件),默认为运行obsutil命令的用户目录的子文件夹.obsutil_output。 说明:
|
bucket-cname | 附加参数,可选 | 指定桶绑定的自定义域名 说明: Util 5.7.9版本及以上支持该参数。 |
config | 附加参数,可选 | 运行当前命令时的自定义配置文件。可支持的配置参数请参考配置参数说明。 |
e | 附加参数,可选 | 指定终端节点。 |
i | 附加参数,可选 | 指定用户的AK。 |
k | 附加参数,可选 | 指定用户的SK。 |
t | 附加参数,可选 | 指定用户的securitytoken。 |
响应结果
请参考上传对象的响应结果。

