您可以在上传文件过程中的任意时间节点中断上传。如果上传的文件较小(例如几KB或者数十KB等),可能存在无法成功中断上传的情况。
注意事项
本文以华东1(杭州)外网Endpoint为例。如果您希望通过与OSS同地域的其他阿里云产品访问OSS,请使用内网Endpoint。关于OSS支持的Region与Endpoint的对应关系,请参见访问域名和数据中心。
本文以OSS域名新建OSSClient为例。如果您希望通过自定义域名、STS等方式新建OSSClient,请参见新建OssClient。
您可以通过中断上传以及取消分片上传两种方式中断需要上传的数据,这两种方式区别如下:
中断上传是指开发者调用上传接口向远程OSS上传文件时,停掉了该调用任务,即取消了本次上传任务。取消分片上传是指通知OSS不再接受该UploadID的分片上传任务。
若进行分片上传任务,中断上传将导致本次分片上传任务被取消,您仍然可以调用该UploadID重新上传。若取消分片上传后,则该UploadID将不可用。
中断上传对所有上传接口均有效。取消分片上传仅针对分片上传有效。
示例代码
以下代码用于中断上传:
#include <alibabacloud/oss/OssClient.h>
#include <fstream>
using namespace AlibabaCloud::OSS;
int main(void)
{
/* 初始化OSS账号信息。*/
/* yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。*/
std::string Endpoint = "yourEndpoint";
/* 填写Bucket名称,例如examplebucket。*/
std::string BucketName = "examplebucket";
/* 填写Object完整路径,完整路径中不能包含Bucket名称,例如exampledir/exampleobject.txt。*/
std::string ObjectName = "exampledir/exampleobject.txt";
/* 初始化网络等资源。*/
InitializeSdk();
ClientConfiguration conf;
/* 从环境变量中获取访问凭证。运行本代码示例之前,请确保已设置环境变量OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。*/
auto credentialsProvider = std::make_shared<EnvironmentVariableCredentialsProvider>();
OssClient client(Endpoint, credentialsProvider, conf);
std::vector<PutObjectOutcomeCallable> Callables;
for (int i=0; i < 4; i++) {
std::shared_ptr<std::iostream> content = std::make_shared<std::fstream>("yourLocalFilename", std::ios::in|std::ios::binary);
PutObjectRequest request(BucketName, ObjectName, content);
auto outcomeCallable = client.PutObjectCallable(request);
Callables.emplace_back(std::move(outcomeCallable));
}
std::this_thread::sleep_for(std::chrono::milliseconds(1000));
/* 中断上传。*/
client.DisableRequest();
for (size_t i = 0; i < Callables.size(); i++) {
auto outcome = Callables[i].get();
if (outcome.error().Code() == "ClientError:100002" ||
outcome.error().Code() == "ClientError:200042") {
std::cout << "disable putobject success" << std::endl;
}
}
/* 释放网络等资源。*/
ShutdownSdk();
return 0;
}
文档内容是否对您有帮助?