使用适用于 .NET 的 Amazon SDK 从 Amazon Glacier 的文件库中下载档案 - Amazon Glacier
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

此页面仅适用于使用文件库和 2012 年原始 REST API 的 Amazon Glacier 服务的现有客户。

如果您正在寻找归档存储解决方案,建议使用 Amazon S3 中的 Amazon Glacier 存储类别 S3 Glacier Instant Retrieval、S3 Glacier Flexible Retrieval 和 S3 Glacier Deep Archive。要了解有关这些存储选项的更多信息,请参阅 Amazon Glacier 存储类别

Amazon Glacier(最初基于保管库的独立服务)不再接受新客户。Amazon Glacier 是一项独立的服务 APIs ,拥有自己的服务,可将数据存储在文件库中,不同于亚马逊 S3 和 Amazon S3 Glacier 存储类别。在 Amazon Glacier 中,您现有的数据将确保安全,并且可以无限期地访问。无需进行迁移。对于低成本、长期的存档存储, Amazon 建议使用 Amazon S3 Glacier 存储类别,这些存储类别基于S3存储桶 APIs、完全 Amazon Web Services 区域 可用性、更低的成本和 Amazon 服务集成,可提供卓越的客户体验。如果您希望加强功能,可以考虑使用我们的 Amazon 将数据从 Amazon Glacier 文件库传输到 Amazon S3 Glacier 存储类别的解决方案指南,迁移到 Amazon S3 Glacier 存储类别。

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

使用适用于 .NET 的 Amazon SDK 从 Amazon Glacier 的文件库中下载档案

以下 C# 代码示例使用适用于 .NET 的 Amazon SDK 高级 API 来下载您在之前的使用适用于 .NET 的 Amazon SDK 将档案上传到 Amazon Glacier 中的文件库步骤中上传的档案。在代码示例中,请注意以下情况:

  • 该示例为指定的 Amazon Glacier 区域端点创建 ArchiveTransferManager 类的实例。

  • 该代码示例使用美国西部(俄勒冈州)区域(us-west-2)匹配您之前在步骤 2:在 Amazon Glacier 中创建文件库中创建文件库的位置。

  • 该示例使用 Download 类的 ArchiveTransferManager API 操作下载档案。该示例将创建 Amazon Simple Notification Service(Amazon SNS)主题,以及该主题订阅的 Amazon Simple Queue Service(Amazon SQS)队列。如果您按照步骤 1:开始使用 Amazon Glacier 之前中的说明创建了 Amazon Identity and Access Management(IAM)管理用户,则您的用户具有必要的 IAM 权限以创建和使用 Amazon SNS 主题和 Amazon SQS 队列。

  • 此示例启动了档案检索任务,并对队列进行轮询以便找到可用档案。如果档案可用,则开始下载。有关检索时间的详细信息,请参阅档案检索选项

有关如何运行以下示例的分步说明,请参阅运行代码示例。您需要更新 步骤 3:在 Amazon Glacier 中将档案上传到文件库 中已上传文件的档案 ID 旁显示的代码。

例—使用适用于 .NET 的 Amazon SDK 高级 API 下载档案
using System; using Amazon.Glacier; using Amazon.Glacier.Transfer; using Amazon.Runtime; namespace glacier.amazon.com.docsamples { class ArchiveDownloadHighLevel_GettingStarted { static string vaultName = "examplevault"; static string archiveId = "*** Provide archive ID ***"; static string downloadFilePath = "*** Provide the file name and path to where to store the download ***"; public static void Main(string[] args) { try { var manager = new ArchiveTransferManager(Amazon.RegionEndpoint.USWest2); var options = new DownloadOptions(); options.StreamTransferProgress += ArchiveDownloadHighLevel_GettingStarted.progress; // Download an archive. Console.WriteLine("Intiating the archive retrieval job and then polling SQS queue for the archive to be available."); Console.WriteLine("Once the archive is available, downloading will begin."); manager.Download(vaultName, archiveId, downloadFilePath, options); Console.WriteLine("To continue, press Enter"); Console.ReadKey(); } catch (AmazonGlacierException e) { Console.WriteLine(e.Message); } catch (AmazonServiceException e) { Console.WriteLine(e.Message); } catch (Exception e) { Console.WriteLine(e.Message); } Console.WriteLine("To continue, press Enter"); Console.ReadKey(); } static int currentPercentage = -1; static void progress(object sender, StreamTransferProgressArgs args) { if (args.PercentDone != currentPercentage) { currentPercentage = args.PercentDone; Console.WriteLine("Downloaded {0}%", args.PercentDone); } } } }