在 Amazon S3 Glacier 中使用Amazon SDK for .NET 在单个操作中上传档案 - Amazon S3 Glacier
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅 中国的 Amazon Web Services 服务入门 (PDF)

如果您不熟悉 Amazon Simple Storage Service (Amazon S3) 中的归档存储功能,建议您先详细了解 Amazon S3 中的 S3 Glacier 存储类、S3 Glacier 即时检索S3 Glacier 灵活检索S3 Glacier 深度归档。有关更多信息,请参阅 Amazon S3 用户指南中的 S3 Glacier 存储类和用于存档对象的存储类。

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

在 Amazon S3 Glacier 中使用Amazon SDK for .NET 在单个操作中上传档案

适用于 .NET 的 Amazon SDK 提供的高级和低级 API 都提供了在单个操作中上传档案的方法。

使用Amazon SDK for .NET的高级 API 上传档案

该高级 API 的 ArchiveTransferManager 类提供了您可以用来将档案上传到文件库的 Upload 方法。

注意

您可以使用 Upload 方法上传小型或大型文件。根据您要上传的文件大小,此方法会确定是在单一操作中上传文件,还是使用分段上传 API 分段上传文件。

示例:使用Amazon SDK for .NET的高级 API 上传档案

以下 C# 代码示例将档案上传到美国西部(俄勒冈州)区域中的文件库 (examplevault)。

有关如何运行以下示例的分步说明,请参阅运行代码示例。您需要更新待上传文件名称旁所显示的代码。

using System; using Amazon.Glacier; using Amazon.Glacier.Transfer; using Amazon.Runtime; namespace glacier.amazon.com.docsamples { class ArchiveUploadHighLevel { static string vaultName = "examplevault"; static string archiveToUpload = "*** Provide file name (with full path) to upload ***"; public static void Main(string[] args) { try { var manager = new ArchiveTransferManager(Amazon.RegionEndpoint.USWest2); // Upload an archive. string archiveId = manager.Upload(vaultName, "upload archive test", archiveToUpload).ArchiveId; Console.WriteLine("Archive ID: (Copy and save this ID for use in other examples.) : {0}", archiveId); 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(); } } }

使用Amazon SDK for .NET低级 API 在单个操作中上传档案

该低级 API 为所有归档操作提供了方法。下面是使用 Amazon SDK for .NET 上传存档的步骤。

  1. 创建 AmazonGlacierClient 类(客户端)的实例。

    您需要指定要上传档案的 Amazon 区域。您使用此客户端执行的所有操作都会应用到该 Amazon 区域。

  2. 通过创建一个 UploadArchiveRequest 类的实例提供请求信息。

    除了您要上传的数据以外,您还需要提供有效负载的校验和(SHA-256 树形哈希)、文件库名称和您的账户 ID。

    如果您不提供账户 ID,则系统会使用与您提供来对请求签名的证书相关联的账户 ID。有关更多信息,请参阅将 Amazon SDK for .NET 与 Amazon S3 Glacier 结合使用

  3. 以参数形式提供请求对象,运行 UploadArchive 方法。

    作为响应,S3 Glacier 返回新上传的档案的档案 ID。

示例:使用Amazon SDK for .NET低级 API 在单个操作中上传档案

以下 C# 代码示例说明了前面的步骤。该示例使用 Amazon SDK for .NET 将档案上传到文件库 (examplevault)。

注意

有关用于在单个请求中上传档案的底层 REST API 的信息,请参阅上传档案(发布档案)

有关如何运行以下示例的分步说明,请参阅运行代码示例。您需要更新待上传文件名称旁所显示的代码。

using System; using System.IO; using Amazon.Glacier; using Amazon.Glacier.Model; using Amazon.Runtime; namespace glacier.amazon.com.docsamples { class ArchiveUploadSingleOpLowLevel { static string vaultName = "examplevault"; static string archiveToUpload = "*** Provide file name (with full path) to upload ***"; public static void Main(string[] args) { AmazonGlacierClient client; try { using (client = new AmazonGlacierClient(Amazon.RegionEndpoint.USWest2)) { Console.WriteLine("Uploading an archive."); string archiveId = UploadAnArchive(client); Console.WriteLine("Archive ID: {0}", archiveId); } } 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 string UploadAnArchive(AmazonGlacierClient client) { using (FileStream fileStream = new FileStream(archiveToUpload, FileMode.Open, FileAccess.Read)) { string treeHash = TreeHashGenerator.CalculateTreeHash(fileStream); UploadArchiveRequest request = new UploadArchiveRequest() { VaultName = vaultName, Body = fileStream, Checksum = treeHash }; UploadArchiveResponse response = client.UploadArchive(request); string archiveID = response.ArchiveId; return archiveID; } } } }