Questa pagina è riservata ai clienti esistenti del servizio S3 Glacier che utilizzano Vaults e l'originale del 2012. REST API
Se stai cercando soluzioni di archiviazione, ti consigliamo di utilizzare le classi di storage S3 Glacier in Amazon S3, S3 Glacier Instant Retrieval, S3 Glacier Flexible Retrieval e S3 Glacier Deep Archive. Per ulteriori informazioni su queste opzioni di storage, consulta le classi di storage S3 Glacier e lo storage dei dati a lungo termine con le classi
Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.
Download di un archivio da un vault in S3 Glacier mediante l'AWS SDK for .NET
L'esempio di codice C# seguente utilizza l'API di alto livello dell'AWS SDK for .NET per eseguire il download dell'archivio caricato precedentemente in Caricamento di un archivio in un vault di S3 Glacier mediante l'AWS SDK for .NET. Nell'esempio di codice, nota quanto segue:
-
L'esempio crea un'istanza della classe
ArchiveTransferManager
per l'endpoint della regione Amazon S3 Glacier specificata. -
L'esempio di codice utilizza la regione Stati uniti occidentali (Oregon) (
us-west-2
), ovvero l'ubicazione in cui hai precedentemente creato il vault in Passaggio 2: creazione di una vault in S3 Glacier. -
L'esempio utilizza l'operazione API
Download
della classeArchiveTransferManager
per eseguire il download dell'archivio. L'esempio crea un argomento Amazon Simple Notification Service (Amazon SNS) e una coda Amazon Simple Queue Service (Amazon SQS) sottoscritta a quell'argomento. Se hai creato un utente amministratore di AWS Identity and Access Management (IAM) come illustrato in Passaggio 1: prima di iniziare a utilizzare S3 Glacier, il tuo utente dispone delle autorizzazioni IAM necessarie per la creazione e l'utilizzo dell'argomento Amazon SNS e della coda Amazon SQS. -
L'esempio quindi avvia il processo di recupero dell'archivio ed esegue il polling della coda affinché l'archivio sia disponibile. Quando l'archivio è disponibile, il download ha inizio. Per informazioni sui tempi di recupero, consulta Opzioni di recupero dall'archivio.
Per istruzioni dettagliate su come eseguire questo esempio, consulta Esecuzione di esempi di codice. Devi aggiornare il codice con l'ID archivio del file che hai caricato in Passaggio 3: caricamento di un archivio in una vault in S3 Glacier come indicato.
Esempio - Download di un archivio mediante l'API di alto livello dell'AWS SDK for .NET
using System; using Amazon.Glacier; using Amazon.Glacier.Transfer; using Amazon.Runtime; namespace glacier.amazon.com.rproxy.goskope.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); } } } }