更新时间:2023-11-09 GMT+08:00
        
          
          
        
      
      
      
      
      
      
      
      
  
      
      
      
        
下载归档存储对象
如果要下载归档存储对象,需要先将归档存储对象恢复。恢复归档存储对象的恢复选项可支持两类,见下表:
| 
       选项  | 
     
       说明  | 
     
       OBS .NET SDK对应值  | 
    
|---|---|---|
| 
       快速恢复  | 
     
       恢复耗时1~5分钟。  | 
     
       RestoreTierEnum.Expedited  | 
    
| 
       标准恢复  | 
     
       恢复耗时3~5小时。默认值。  | 
     
       RestoreTierEnum.Standard  | 
    
 
  重复恢复归档存储数据时在延长恢复有效期的同时,也将会对恢复时产生的恢复费用进行重复收取。产生的标准存储类别的对象副本有效期将会延长,并且收取延长时间段产生的标准存储副本费用。
您可以通过ObsClient.RestoreObject恢复归档存储对象。以下代码展示了如何下载归档存储对象:
// 初始化配置参数
ObsConfig config = new ObsConfig();
config.Endpoint = "https://your-endpoint";
// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量AccessKeyID和SecretAccessKey。
// 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/intl/zh-cn/usermanual-ca/ca_01_0003.html
string accessKey= Environment.GetEnvironmentVariable("AccessKeyID", EnvironmentVariableTarget.Machine);
string secretKey= Environment.GetEnvironmentVariable("SecretAccessKey", EnvironmentVariableTarget.Machine);
// 创建ObsClient实例
ObsClient client = new ObsClient(accessKey, secretKey, config);
try
{
    RestoreObjectRequest request = new RestoreObjectRequest();
    request.BucketName = "bucketname";
    request.ObjectKey = "objectname";
    request.Days = 5;
    request.Tier = RestoreTierEnum.Expedited;
    // 可选参数,默认情况下,恢复的是最新版本的对象。如果要恢复指定版本的对象,则可携带versionId参数
    // request.VersionId = "versionId";
    RestoreObjectResponse response = client.RestoreObject(request);
    Console.WriteLine("Restore object response: {0}", response.StatusCode);
}
catch (ObsException ex)
{
   Console.WriteLine("ErrorCode: {0}", ex.ErrorCode);
   Console.WriteLine("ErrorMessage: {0}", ex.ErrorMessage);
}
 
 
  - ObsClient.RestoreObject中指定的对象必须是归档存储类型,否则调用该接口会抛出异常。
 - RestoreObjectRequest.Days指定恢复对象保存的时间,取值范围是1~30。
 - RestoreObjectRequest.Tier指定恢复选项,表示恢复对象所耗的时间。
 
   父主题: 下载对象