使用 AWS Command Line Interface在 Amazon S3 Glacier 中删除档案 - Amazon S3 Glacier

此页面仅适用于使用保管库的 S3 Glacier 服务的现有客户以及 2012 年以RESTAPI来的原始客户。

如果您正在寻找档案存储解决方案,我们建议您在亚马逊 S3、S3 Glacier 即时检索、S3 Glacier 灵活检索和 S3 Glacier Deep Archive Dee p Archive 中使用 S3 Glacier 存储类。要了解有关这些存储选项的更多信息,请参阅 Amazon S3 用户指南中的 S3 Glacier 存储类和使用 S3 Glacier 存储类的长期数据存储。这些存储类别使用 Amazon S3API,适用于所有区域,并且可以在 Amazon S3 控制台中进行管理。它们提供存储成本分析、存储镜头、高级可选加密功能等功能。

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

使用 AWS Command Line Interface在 Amazon S3 Glacier 中删除档案

您可以使用 () 删除亚马逊 S3 Glacier (S3 Glacier AWS CLI) 中的 AWS Command Line Interface 档案。

(先决条件)设置 AWS CLI

  1. 下载并配置 AWS CLI。有关说明,请参阅《AWS Command Line Interface 用户指南》中的以下主题:

    正在安装 AWS Command Line Interface

    配置 AWS Command Line Interface

  2. 在命令提示符下输入以下命令来验证您的 AWS CLI 设置。这些命令没有显式提供凭证,因此将使用默认配置文件的凭证。

    • 尝试使用 help 命令。

      aws help
    • 要获取已配置账户上 S3 Glacier 文件库的列表,请使用 list-vaults 命令。Replace(替换) 123456789012 用你的 AWS 账户 身份证。

      aws glacier list-vaults --account-id 123456789012
    • 要查看的当前配置数据 AWS CLI,请使用aws configure list命令。

      aws configure list

示例:使用删除档案 AWS CLI

  1. 使用 initiate-job 命令启动清单检索作业。

    aws glacier initiate-job --vault-name awsexamplevault --account-id 111122223333 --job-parameters="{\"Type\":\"inventory-retrieval\"}"

    预期输出:

    { "location": "/111122223333/vaults/awsexamplevault/jobs/*** jobid ***", "jobId": "*** jobid ***" }
  2. 使用 describe-job 命令检查上一个检索作业的状态。

    aws glacier describe-job --vault-name awsexamplevault --account-id 111122223333 --job-id *** jobid ***

    预期输出:

    { "InventoryRetrievalParameters": { "Format": "JSON" }, "VaultARN": "*** vault arn ***", "Completed": false, "JobId": "*** jobid ***", "Action": "InventoryRetrieval", "CreationDate": "*** job creation date ***", "StatusCode": "InProgress" }
  3. 等待作业完成。

    您必须等到任务输出已作好供您下载的准备。如果您在文件库上设置了通知配置或在启动任务时指定了亚马逊简单通知服务 (AmazonSNS) 主题,则 S3 Glacier 将在任务完成后向该主题发送一条消息。

    您可以设置文件库的特定事件的通知配置。有关更多信息,请参阅 在 Amazon S3 Glacier 中配置文件库通知。每当特定事件发生时,S3 Glacier 都会向指定SNS主题发送一条消息。

  4. 完成后,使用 get-job-output 命令将检索作业下载到文件 output.json

    aws glacier get-job-output --vault-name awsexamplevault --account-id 111122223333 --job-id *** jobid *** output.json

    此命令会生成一个包含以下字段的文件。

    { "VaultARN":"arn:aws:glacier:region:111122223333:vaults/awsexamplevault", "InventoryDate":"*** job completion date ***", "ArchiveList":[ {"ArchiveId":"*** archiveid ***", "ArchiveDescription":*** archive description (if set) ***, "CreationDate":"*** archive creation date ***", "Size":"*** archive size (in bytes) ***", "SHA256TreeHash":"*** archive hash ***" } {"ArchiveId": ... ]}
  5. 使用 delete-archive 命令从文件库中删除每个存档,直到不保留任何存档。

    aws glacier delete-archive --vault-name awsexamplevault --account-id 111122223333 --archive-id *** archiveid ***