AWS CLIでS3バケットを削除してみます。
前提条件
S3への権限
S3に対してフル権限があること。
AWS CLIのバージョン
以下のバージョンで動作確認済
- AWS CLI 1.11.28
コマンド
aws --version
結果(例):
aws-cli/1.11.70 Python/2.7.12 Linux/4.4.11-23.53.amzn1.x86_64 botocore/1.5.33
バージョンが古い場合は最新版に更新しましょう。
コマンド
sudo -H pip install -U awscli
- 準備
=======
まず変数の確認をします。
変数の確認
cat << ETX
AWS_DEFAULT_PROFILE: (0.1) ${AWS_DEFAULT_PROFILE}
AWS_DEFAULT_REGION: (0.2) ${AWS_DEFAULT_REGION}
ETX
結果(例):
AWS_DEFAULT_PROFILE: (0.1) <s3のフル権限を許可されているプロファイル>
AWS_DEFAULT_REGION: (0.2) ap-northeast-1
変数が入っていない、適切でない場合は、それぞれの手順番号について作業を
行います。
0.1. プロファイルの指定
プロファイルの一覧を確認します。
コマンド
cat ~/.aws/credentials \
| grep '\[' \
| sed 's/\[//g' | sed 's/\]//g'
結果(例):
iamFull-prjz-mbpr13
<s3のフル権限を許可されているプロファイル>
変数の設定
export AWS_DEFAULT_PROFILE='<s3のフル権限を許可されているプロファイル>'
0.2. リージョンの指定
変数の設定
export AWS_DEFAULT_REGION='ap-northeast-1'
最終確認
変数の確認
cat << ETX
AWS_DEFAULT_PROFILE: (0.1) ${AWS_DEFAULT_PROFILE}
AWS_DEFAULT_REGION: (0.2) ${AWS_DEFAULT_REGION}
ETX
結果(例):
AWS_DEFAULT_PROFILE: (0.1) <s3のフル権限を許可されているプロファイル>
AWS_DEFAULT_REGION: (0.2) ap-northeast-1
- 事前作業
===========
1.1. バケット名の指定
削除するバケット名を指定します。
変数の設定
S3_BUCKET_PREFIX='<削除するバケット名を特定する文字列>'
コマンド
S3_BUCKET_NAME=$( \
aws s3api list-buckets \
--query "Buckets[?contains(Name,\`${S3_BUCKET_PREFIX}\`)].Name" \
--output text \
) \
&& echo ${S3_BUCKET_NAME}
結果(例):
<削除するバケット名>
1.2. バケットのリージョン確認
バケットのリージョンを確認します。
コマンド
aws s3api get-bucket-location \
--bucket ${S3_BUCKET_NAME}
結果(例):
{
"LocationConstraint": "ap-northeast-1"
}
1.3. バケットの中身の確認
コマンド
aws s3 ls s3://${S3_BUCKET_NAME}/
結果(例):
(戻り値なし)
もしオブジェクトが存在する場合は、削除します。
コマンド
aws s3 rm s3://${S3_BUCKET_NAME} \
--recursive
結果(例):
delete: s3://<削除するバケット名>/<削除するオブジェクト名>
- バケットの削除
=================
コマンド
aws s3api delete-bucket \
--bucket ${S3_BUCKET_NAME}
結果(例):
(戻り値なし)
- 事後確認
===========
コマンド
aws s3 ls s3://${S3_BUCKET_NAME}/
結果(例):
A client error (NoSuchBucket) occurred when calling the ListObjects operation: The specified bucket does not exist