You need to enable JavaScript to run this app.
导航

恢复对象(C++ SDK)

最近更新时间2024.02.04 18:31:06

首次发布时间2023.08.03 16:36:18

对冷归档对象进行恢复,恢复之后可以通过下载对象接口获取到对象。通过参数可以指定不同的取回方式。

注意事项

  • 第一次调用 restoreObject 接口,返回 202。如果文件正在恢复中,再次调用 restoreObject 接口,会返回 409 错误。如果对象已完成恢复,再次调用 restoreObject 接口返回 200 OK。
  • 对于开启多版本的桶,可以通过指定 versionId 恢复指定版本的对象,如果未指定 versionId,默认恢复当前对象。

示例代码

以下代码用于恢复对象。

#include "TosClientV2.h"
using namespace VolcengineTos;

int main(void){
    // 初始化 TOS 账号信息
    // Your Region 填写 Bucket 所在 Region
    std::string region = "Your Region";
    std::string accessKey = std::getenv("TOS_ACCESS_KEY");
    std::string secretKey = std::getenv("TOS_SECRET_KEY");
    // 填写 Bucket 名称,例如 examplebucket
    std::string bucketName = "examplebucket";
    // 填写Object完整路径,完整路径中不能包含Bucket名称,例如exampledir/exampleobject.txt。
    std::string objectName = "exampledir/exampleobject.txt";
    
    // 初始化网络等资源
    InitializeClient();
    // 创建交互的 client
    TosClientV2 client(region, accessKey, secretKey);
    
    RestoreObjectInput input(bucketName, objectName, 10, RestoreJobParameters(TierType::TierExpedited));
    auto output = client.restoreObject(input);
    if (!output.isSuccess()) {
        // 异常处理
        std::cout << "RestoreObject failed." << output.error().String() << std::endl;
        // 释放网络等资源
        CloseClient();
        return -1;
    }
    std::cout << "RestoreObject success." << std::endl;
    
    // 释放网络等资源
    CloseClient();
    return 0;
}

相关文档

关于恢复对象接口的详细介绍,请参见 RestoreObject