更新时间:2023-11-09 GMT+08:00

下载归档存储对象

开发过程中,您有任何问题可以在github上提交issue接口参考文档详细介绍了每个接口的参数和使用方法。

如果要下载归档存储对象,需要先将归档存储对象恢复。恢复归档存储对象的恢复选项可支持两类,见下表:

选项

说明

OBS Node.js SDK对应值

快速恢复

恢复耗时1~5分钟。

ObsClient.enums.RestoreTierExpedited

标准恢复

恢复耗时3~5小时。默认值。

ObsClient.enums.RestoreTierStandard

重复恢复归档存储数据时在延长恢复有效期的同时,也将会对恢复时产生的恢复费用进行重复收取。产生的标准存储类别的对象副本有效期将会延长,并且收取延长时间段产生的标准存储副本费用。

您可以通过ObsClient.restoreObject恢复归档存储对象。以下代码展示了如何下载归档存储对象:

// 引入obs库
// 使用npm安装
var ObsClient = require('esdk-obs-nodejs');
// 使用源码安装
// var ObsClient = require('./lib/obs');

// 创建ObsClient实例
var obsClient = new ObsClient({
       //推荐通过环境变量获取AKSK,这里也可以使用其他外部引入方式传入,如果使用硬编码可能会存在泄露风险。
       //您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/intl/zh-cn/usermanual-ca/ca_01_0003.html
       access_key_id: process.env.ACCESS_KEY_ID,
       secret_access_key: process.env.SECRET_ACCESS_KEY,
       server : 'https://your-endpoint'
});

// 恢复归档存储对象
obsClient.restoreObject({
       Bucket : 'bucketname',
       Key : 'objectname',
       Days : 1,
       Tier : obsClient.enums.RestoreTierExpedited
}, (err, result) => {
       if(err){
              console.error('Error-->' + err);
       }else{
              console.log('Status-->' + result.CommonMsg.Status);
              
              // 等待对象恢复
              setTimeout(()=>{
                     
                     // 下载对象, 获取对象内容
                     obsClient.getObject({
                           Bucket : 'bucketname',
                           Key : 'objectname'
                     }, (err, result) => {
                            if(err){              
                               console.error('Error-->' + err);       
                            }else{              
                               console.log('Status-->' + result.CommonMsg.Status); 
                               if(result.CommonMsg.Status < 300 && result.InterfaceResult){     
                                   // 读取对象内容                           
                                   console.log('Object Content:');                            
                                   console.log(result.InterfaceResult.Content.toString());   
                               }    
                            }
                     });
              }, 6 * 60 * 1000);
       }
});
  • ObsClient.restoreObject中指定的对象必须是归档存储类型,否则调用该接口会报错。
  • 使用Days参数指定恢复对象保存的时间,取值范围是1~30;使用Tier参数指定恢复选项,表示恢复对象所耗的时间。