本文介绍如何解冻归档(Archive)及冷归档(Cold Archive)类型的文件(Object)。
说明 非归档或冷归档类型的文件,不要调用RestoreObject方法。
归档及冷归档类型的详细说明请参见存储类型介绍。相关状态码的详细解释请参见API文档RestoreObject。
解冻归档文件
归档类型的Object在执行解冻前后的状态变换过程如下:
- 归档类型的Object初始时处于冷冻状态。
- 提交一次解冻请求后,Object处于解冻中的状态,完成解冻任务通常需要1分钟。
- 服务端完成解冻任务后,Object进入解冻状态,此时您可以读取Object。解冻状态默认持续24小时,24小时内再次调用RestoreObject接口则解冻状态会自动延长24小时。对于同份归档文件,一次解冻流程内可有效调用7次RestoreObject接口达到最长7天的解冻持续时间。
- 解冻状态结束后,Object再次返回到冷冻状态。
以下代码用于解冻归档文件:
#include <alibabacloud/oss/OssClient.h> #include <thread> #include <chrono> using namespace AlibabaCloud::OSS; int main(void) { /* 初始化OSS账号信息 */ std::string AccessKeyId = "yourAccessKeyId"; std::string AccessKeySecret = "yourAccessKeySecret"; std::string Endpoint = "yourEndpoint"; std::string BucketName = "yourBucketName"; std::string ObjectName = "yourObjectName"; /* 初始化网络等资源 */ InitializeSdk(); ClientConfiguration conf; OssClient client(Endpoint, AccessKeyId, AccessKeySecret, conf); /* 解冻归档文件 */ auto outcome = client.RestoreObject(BucketName, ObjectName); /* 非归档文件不能解冻 */ if (!outcome.isSuccess()) { /* 异常处理 */ std::cout << "RestoreObject fail" << ",code:" << outcome.error().Code() << ",message:" << outcome.error().Message() << ",requestId:" << outcome.error().RequestId() << std::endl; ShutdownSdk(); return -1; } std::string onGoingRestore("ongoing-request=\"false\""); int maxWaitTimeInSeconds = 600; while (maxWaitTimeInSeconds > 0) { auto meta = client.HeadObject(BucketName, ObjectName); std::string restoreStatus = meta.result().HttpMetaData()["x-oss-restore"]; std::transform(restoreStatus.begin(), restoreStatus.end(), restoreStatus.begin(), ::tolower); if (!restoreStatus.empty() && restoreStatus.compare(0, onGoingRestore.size(), onGoingRestore)==0) { std::cout << " success, restore status:" << restoreStatus << std::endl; /* 成功解冻归档文件*/ break; } std::cout << " info, WaitTime:" << maxWaitTimeInSeconds << "; restore status:" << restoreStatus << std::endl; std::this_thread::sleep_for(std::chrono::seconds(10)); maxWaitTimeInSeconds--; } if (maxWaitTimeInSeconds == 0) { std::cout << "RestoreObject fail, TimeoutException" << std::endl; } /* 释放网络等资源 */ ShutdownSdk(); return 0; }
解冻冷归档文件
冷归档类型的Object在执行解冻前后的状态变换过程如下:
- 冷归档类型的Object初始时处于冷冻状态。
- 提交一次解冻请求后,Object处于解冻中的状态。不同优先级的首字节取回时间如下:
- 高优先级(Expedited):表示1小时内完成解冻。
- 标准(Standard):表示2~5小时内完成解冻。如果不传入JobParameters节点,则默认为Standard。
- 批量(Bulk):表示5~12小时内完成解冻。
- 服务端完成解冻任务后,Object进入解冻状态,此时您可以读取Object。您可以指定解冻的天数,最短是1天,最长是7天。
- 解冻状态结束后,Object再次返回到冷冻状态。
以下代码用于解冻冷归档文件:
#include <alibabacloud/oss/OssClient.h> using namespace AlibabaCloud::OSS; int main(void) { /* 初始化OSS账号信息 */ std::string AccessKeyId = "yourAccessKeyId"; std::string AccessKeySecret = "yourAccessKeySecret"; std::string Endpoint = "yourEndpoint"; std::string BucketName = "yourBucketName"; std::string ObjectName = "yourObjectName"; /* 初始化网络等资源 */ InitializeSdk(); ClientConfiguration conf; OssClient client(Endpoint, AccessKeyId, AccessKeySecret, conf); /* 如果上传文件的同时指定文件存储类型为冷归档,请参考如下代码 */ //auto content = std::make_shared<std::stringstream>("test"); //PutObjectRequest putRequest(BucketName, ObjectName, content); //putRequest.MetaData().addHeader("x-oss-storage-class", "ColdArchive"); //auto putOutcome = client.PutObject(putRequest); RestoreObjectRequest request(BucketName, ObjectName); /* 设置解冻之后保持解冻状态的天数,默认值为1天 */ request.setDays(2); /* 设置解冻冷归档类型文件的优先级 */ request.setTierType(TierType::Expedited); auto outcome = client.RestoreObject(request); if (!outcome.isSuccess()) { /* 异常处理 */ std::cout << "Delete Bucket Inventory fail" << ",code:" << outcome.error().Code() << ",message:" << outcome.error().Message() << ",requestId:" << outcome.error().RequestId() << std::endl; } /* 释放网络等资源 */ ShutdownSdk(); return 0; }