S3バケット"handson-cli-s3-object-XXXXXXXXXXXX"にファイルをアップロードします。
作業に必要なパラメータを変数に格納をします。
0. プロファイルの指定
AWS認証ファイルを指定します。
環境変数の設定: export AWS_SHARED_CREDENTIALS_FILE="${HOME}/environment/credentials-handson-cli-s3-MaintUser/handson-cli-s3-MaintUser.ini"
環境変数の設定:
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'
export AWS_DEFAULT_PROFILE='handson-cli-s3-MaintUser'
1. S3バケット名
S3バケット名を指定します。
変数の設定: S3_BUCKET_PREFIX='handson-cli-s3-object' コマンド: 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-object-XXXXXXXXXXXX
変数の設定:
S3_BUCKET_PREFIX='handson-cli-s3-object'
コマンド:
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-object-XXXXXXXXXXXX
2. S3オブジェクトキー
アップロードするファイルの保存先(オブジェクトキー)を指定します。
変数の設定: S3_OBJECT_KEY='alpha/0.txt'
S3_OBJECT_KEY='alpha/0.txt'
各変数に正しいパラメータ値が格納されていることを確認します。
変数の確認: 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-object-XXXXXXXXXXXX" S3_BUCKET_NAME="${S3_BUCKET_NAME}" # 2. S3_OBJECT_KEY:"alpha/0.txt" S3_OBJECT_KEY="${S3_OBJECT_KEY}" END
変数の確認:
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-object-XXXXXXXXXXXX" S3_BUCKET_NAME="${S3_BUCKET_NAME}" # 2. S3_OBJECT_KEY:"alpha/0.txt" S3_OBJECT_KEY="${S3_OBJECT_KEY}" END
S3オブジェクトを更新します。
コマンド: aws s3api put-object \ --bucket ${S3_BUCKET_NAME} \ --key ${S3_OBJECT_KEY} \ --metadata secretlevel=1,Category=intra 結果(例): { "ETag": "\"xxxxxxxxxxxxxxxxxxxxx\"" }
aws s3api put-object \ --bucket ${S3_BUCKET_NAME} \ --key ${S3_OBJECT_KEY} \ --metadata secretlevel=1,Category=intra
{ "ETag": "\"xxxxxxxxxxxxxxxxxxxxx\"" }
S3オブジェクトを確認します。
コマンド: aws s3api head-object \ --bucket ${S3_BUCKET_NAME} \ --key ${S3_OBJECT_KEY} 結果(例): { "AcceptRanges": "bytes", "LastModified": "Thu, 26 Nov 2020 08:54:29 GMT", "ContentLength": 0, "ETag": "\"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\"", "ContentType": "binary/octet-stream", "Metadata": { "category": "intra", "secretlevel": "1" } }
aws s3api head-object \ --bucket ${S3_BUCKET_NAME} \ --key ${S3_OBJECT_KEY}
{ "AcceptRanges": "bytes", "LastModified": "Thu, 26 Nov 2020 08:54:29 GMT", "ContentLength": 0, "ETag": "\"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\"", "ContentType": "binary/octet-stream", "Metadata": { "category": "intra", "secretlevel": "1" } }
環境変数を削除して、プロファイルの権限を無効にします。
環境変数の設定: export -n AWS_DEFAULT_PROFILE
export -n AWS_DEFAULT_PROFILE