ハンズオン(簡易版): S3基礎 バージョニング

3.6. S3オブジェクトのバージョン削除 (handson-cli-s3-versioning-XXXXXXXXXXXX/handson-cli-s3.txt)

目的

S3バケット"handson-cli-s3-versioning-XXXXXXXXXXXX"のオブジェクト"handson-cli-s3.txt"の"0"世代前のバージョンを削除します。

パラメータの指定

作業に必要なパラメータを変数に格納をします。

0. プロファイルの指定

AWS認証ファイルを指定します。

環境変数の設定:

export AWS_SHARED_CREDENTIALS_FILE="${HOME}/environment/credentials-handson-cli-s3-MaintUser/handson-cli-s3-MaintUser.ini"

プロファイルを指定します。

環境変数の設定:

export AWS_DEFAULT_PROFILE='handson-cli-s3-MaintUser'

1. S3バケット名

S3バケット名を指定します。

変数の設定:

S3_BUCKET_PREFIX='handson-cli-s3-versioning'

コマンド:

AWS_ID=$( \
  aws sts get-caller-identity \
    --query 'Account' \
    --output text \
) \
  && echo ${AWS_ID}

結果(例):

XXXXXXXXXXXX

変数の設定:

S3_BUCKET_NAME="${S3_BUCKET_PREFIX}-${AWS_ID}" \
  && echo ${S3_BUCKET_NAME}

結果(例):

handson-cli-s3-versioning-XXXXXXXXXXXX

2. S3オブジェクトキー

オブジェクトキーを指定します。

変数の設定:

S3_OBJECT_KEY='handson-cli-s3.txt'

3. S3オブジェクトの前世代数

S3オブジェクトの前世代数を指定します。

変数の設定:

COUNT_OLDER='0'

各変数に正しいパラメータ値が格納されていることを確認します。

変数の確認:

cat << END

  # 0. AWS_SHARED_CREDENTIALS_FILE:"${HOME}/environment/credentials-handson-cli-s3-MaintUser/handson-cli-s3-MaintUser.ini"
       AWS_SHARED_CREDENTIALS_FILE="${AWS_SHARED_CREDENTIALS_FILE}"
  #    AWS_DEFAULT_PROFILE:"handson-cli-s3-MaintUser"
       AWS_DEFAULT_PROFILE="${AWS_DEFAULT_PROFILE}"

  # 1. S3_BUCKET_NAME:"handson-cli-s3-versioning-XXXXXXXXXXXX"
       S3_BUCKET_NAME="${S3_BUCKET_NAME}"
  # 2. S3_OBJECT_KEY:"handson-cli-s3.txt"
       S3_OBJECT_KEY="${S3_OBJECT_KEY}"
  # 3. COUNT_OLDER:"0"
       COUNT_OLDER="${COUNT_OLDER}"

END

手順

オブジェクトのバージョンIDを取得します。

コマンド:

S3_OBJECT_VERSION_ID=$( \
  aws s3api list-object-versions \
    --bucket ${S3_BUCKET_NAME} \
    --prefix ${S3_OBJECT_KEY} \
    --query "reverse(sort_by(Versions, &LastModified))["${COUNT_OLDER}"].VersionId" \
    --output text \
) \
  && echo ${S3_OBJECT_VERSION_ID}

結果(例):

yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy

オブジェクトのバージョンを削除します。

変数の確認:

cat << ETX

  # S3_BUCKET_NAME:"handson-cli-s3-versioning-XXXXXXXXXXXX"
    S3_BUCKET_NAME="${S3_BUCKET_NAME}"
  # S3_OBJECT_KEY:"handson-cli-s3.txt"
    S3_OBJECT_KEY="${S3_OBJECT_KEY}"
  # S3_OBJECT_VERSION_ID:"yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy"
    S3_OBJECT_VERSION_ID="${S3_OBJECT_VERSION_ID}"

ETX

コマンド:

aws s3api delete-object \
  --bucket ${S3_BUCKET_NAME} \
  --key ${S3_OBJECT_KEY} \
  --version-id ${S3_OBJECT_VERSION_ID}

結果(例):

{
  "VersionId": "yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy"
}

完了確認

「S3バケット"handson-cli-s3-versioning-XXXXXXXXXXXX"のオブジェクト"handson-cli-s3.txt"に"0"世代前のバージョンが存在しない。」ことを確認します。

コマンド:

aws s3api list-object-versions \
  --bucket ${S3_BUCKET_NAME} \
  --prefix ${S3_OBJECT_KEY} \
  --query "Versions[?VersionId == \`${S3_OBJECT_VERSION_ID}\`].VersionId" \
  --output text

結果(例):

(出力なし)

環境変数を削除して、プロファイルの権限を無効にします。

環境変数の設定:

export -n AWS_DEFAULT_PROFILE