本文介绍如何解冻归档文件。

归档类型(Archive)的文件需要解冻(Restore)之后才能读取。非归档类型的文件,无需调用 RestoreObject 方法。

归档文件的状态变换过程如下:

  • 归档类型的文件初始时处于冷冻状态。
  • 提交解冻操作后,服务端执行解冻,文件处于解冻中的状态。
    说明 通常情况下,归档类型文件解冻时间约为 1 分钟。
  • 完成解冻后,可以读取文件。解冻状态默认持续 1 天,最多延长 7 天,之后文件回到冷冻状态。
以下代码用于解冻归档文件:
#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;
}

归档存储类型的详细说明请参见存储类型介绍。相关状态码的详细解释请参见API文档RestoreObject