您可以通过 cp
命令将本地对象上传至 TOS。
上传单个对象
./tosutil cp file_url tos://bucket[/key] [-dryRun] [-link] [-u] [-vchecksum] [-p=1] [-threshold=52428800] [-ps=auto] [-cpd=xxx] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-sse=xxx] [-sseKeyId=xxx] [-contentType=xxx] [-contentDisposition=xxx] [-contentEncoding=xxx] [-contentLanguage=xxx] [-cacheControl=xxx] [-expires=xxx] [-arcDir=xxx] [-fr] [-o=xxx] [-e=xxx] [-re=xxx] [-i=xxx] [-k=xxx] [-t=xxx] [-conf=xxx]
上传文件夹
./tosutil cp folder_url tos://bucket[/prefix] -r [-dryRun] [-link] [-u] [-vchecksum] [-flat] [-j=1] [-p=1] [-threshold=104857600] [-nfj=1] [-ps=auto] [-cpd=xxx] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-sse=xxx] [-sseKeyId=xxx] [-contentType=xxx] [-contentDisposition=xxx] [-contentEncoding=xxx] [-contentLanguage=xxx] [-cacheControl=xxx] [-expires=xxx] [-include=*.xxx] [-exclude=*.xxx] [-timeRange=time1-time2] [-at] [-ddo] [-dmf] [-arcDir=xxx] [-o=xxx] [-e=xxx] [-re=xxx] [-i=xxx] [-k=xxx] [-t=xxx] [-conf=xxx]
上传文件列表
./tosutil cp file1_url,folder1_url|filelist_url tos://bucket[/prefix] -msm=1 [-r] [-dryRun] [-link] [-u] [-vchecksum] [-flat] [-j=1] [-p=1] [-threshold=104857600] [-nfj=1] [-ps=auto] [-cpd=xxx] [-acl=xxx] [-sc=xxx] [-meta=aaa:bbb#ccc:ddd] [-sse=xxx] [-sseKeyId=xxx] [-contentType=xxx] [-contentDisposition=xxx] [-contentEncoding=xxx] [-contentLanguage=xxx] [-cacheControl=xxx] [-expires=xxx] [-include=*.xxx] [-exclude=*.xxx] [-timeRange=time1-time2] [-at] [-ddo] [-dmf] [-arcDir=xxx] [-o=xxx] [-e=xxx] [-re=xxx] [-i=xxx] [-k=xxx] [-t=xxx] [-conf=xxx]
tosutil 支持通过 -j
及 -p
参数调整并发数。当您批量上传大文件时,实际并发数为 -j
乘以 -p
参数。调整建议如下:
-nfj
参数和 -j
参数分别控制非分片任务和分片任务的并发数。例如设置 -j=100,-nfj=80
,表示总并发数为 100,当执行非分片任务(一般是小文件)时,最大的并发数为 80;当执行分片任务(一般是大文件)时,最大的并发数为 20。maxRetryCount
参数,通过不断重试错误解决公网网络不稳定的问题。-j
和 -p
参数,避免因并发过高导致客户端超带宽,进而出现断流失败等情况。-ps
参数,降低分片大小,有利于提高单个分片上传/下载/复制的成功率。注意
在海量小文件场景中,如果您设置了较高的 -j
,导致 TPS 超过 1000,您需要同步上调 maxConnections
参数,更多信息,请参见配置文件说明。
通用可选参数的说明,请参见通用可选参数。
参数名 | 参数类型 | 描述 |
---|---|---|
file_url | String | 本地文件路径。 说明 如果您需要上传文件列表,可在命令中添加多个 |
folder_url | String | 本地文件夹路径,需要 |
bucket | String | 桶名。 |
key | String | 对象名。 |
prefix | String | 批量操作时的对象名前缀。 |
-r | Bool | 执行批量上传、下载或复制操作。 |
-dryRun | Bool | 测试模式运行,不执行实际的上传、下载或复制操作。 |
-link | Bool | 上传软链接文件或文件夹指向的真实路径。 |
-msm | Enum | 开启多文件或文件夹上传模式,说明如下:
注意
|
-recover | String | 待恢复上传、下载或复制对象任务的结果清单文件任务 ID。 |
-u | Bool | 增量上传、下载或复制对象,设置该参数后,会比较源端和目标端,建议您在以下情况下使用:
|
-vchecksum | Bool | 上传或下载对象时通过 CRC64 算法验证数据一致性。 |
-flat | Bool | 上传、下载或复制对象时不包含相对父目录。 |
-j | Integer | 批量任务的最大并发数,默认为配置文件中的 |
-p | Integer | 每个分片任务的最大并发数,默认为配置文件中的 |
-threshold | Integer | 开启分片任务的阈值,单位为字节,默认为配置文件中的 说明 支持带容量单位配置,例如,配置 1MB 代表 1048576 字节。 |
-nfj | Integer | 批量任务的处理普通文件或对象(非分片任务)的最大并发数。当设置该参数后, |
-ps | Integer/String | 每个分片任务的段大小,单位为字节,默认为配置文件中的 说明 支持带容量单位配置,例如,配置 1MB 代表 1048576 字节。 |
-cpd | String | 生成断点记录文件的文件夹,默认为配置文件中的 |
-acl | String | 上传或复制对象时可指定的预定义访问策略。支持的值如下:
|
-sc | Enum | 上传对象时可指定的对象存储类型,取值说明如下:
说明
|
-meta | String | 上传或复制对象时可指定的自定义元数据。 |
-sse | String | 上传、复制对象时使用的服务端加密算法,支持的值:
默认为配置文件中的 defaultSse。 |
-sseKeyId | String | 上传、复制对象且指定服务端加密算法为 kms 时,使用的 kms 密钥,默认为配置文件中的 defaultSseKeyId。 |
-contentType | String | 上传、复制对象时设置对象的 Content-Type。 |
-contentDisposition | String | 上传、复制对象时设置对象的 Content-Disposition。 |
-contentEncoding | String | 上传、复制对象时设置对象的 Content-Encoding。 |
-contentLanguage | String | 上传、复制对象时设置对象的 Content-Language。 |
-cacheControl | String | 上传、复制对象时设置对象的 Cache-Control。 |
-expires | String | 上传、复制对象时设置对象的 Expires,格式为:YYYYMMDDHHmmSS。 |
-include | String | 上传、下载或复制时对包含文件的名称匹配模式,支持以下字符:
例如 说明
|
-exclude | String | 上传、下载或复制时对不包含文件的名称匹配模式,支持以下字符:
例如 说明
|
-timeRange | String | 上传、下载或复制时文件最后修改时间的时间段匹配模式,格式为: |
-at | Bool | 上传文件夹中文件的最后访问时间满足 |
-ddo | Bool | 上传时文件夹本身不会作为单独一个对象上传。 |
-dmf | Bool | 设置名称匹配模式 |
-arcDir | String | 上传文件成功后的归档文件夹。 |
-fr | Bool | 操作单个对象时生成结果清单文件。 |
-o | String | 生成结果清单文件的文件夹,默认为配置文件中的 |
以下命令用于将 /Users/Downloads/TOS/tosutil 文件夹中的 object 文件上传至 bucketname 存储桶,上传后文件名为 object。
命令
./tosutil cp /Users/Downloads/TOS/tosutil/object tos://bucketname/object
返回
Start at 2022-10-27 10:49:12.407874 +0000 UTC Parallel: 1 Jobs: 5 Threshold: 100.00MB PartSize: auto VerifyChecksum: false CheckpointDir: /.tosutil_checkpoint [-------------------------------------------] 100.00% ?/s 50.50KB/50.50KB 162ms Upload successfully, 50.50KB, n/a, /Users/Downloads/TOS/tosutil/object --> tos://bucketname/object, cost [164], status [200], request id [2643485a6228acbb635a6228-ac1173a1-1oo0Rk-PuO-cb-tos-bj-3]
以下命令用于将 /Users/Downloads/TOS/tosutil 文件夹中的所有文件上传至 bucketname 存储桶,上传后文件夹命名为 cpfile。
说明
该命令会上传文件夹本身,上传后所有的文件仍在 cpfile 文件夹内。
命令
./tosutil cp /Users/Downloads/TOS/tosutil tos://bucketname/cpfile -r
返回
Start at 2022-10-27 10:50:43.872787 +0000 UTC Parallel: 1 Jobs: 5 Threshold: 100.00MB PartSize: auto VerifyChecksum: false CheckpointDir: /Users/.tosutil_checkpoint OutputDir: /Users/.tosutil_output [----------------------------] 100.00% tps:0.00 ?/s 4/4 181.45KB/181.45KB 183ms Succeed count is: 4 Failed count is: 0 Succeed bytes is: 181.45KB Metrics [max cost:178 ms, min cost:103 ms, average cost:143.75 ms, average tps:21.62] Task id is: 34c8480e-55e5-11ed-806b-aa665a3c7f26
说明
更多上传场景的示例命令,请参见上传示例。