ハンズオン(簡易版): S3基礎 Webサイト&ログ

3.3. S3バケット(Webサイト)へのアクセス (handson-cli-s3-website-logging-website-XXXXXXXXXXXX)

目的

コンテンツ用S3バケット"handson-cli-s3-website-logging-website-XXXXXXXXXXXX"にアクセスし、コンテンツの確認をします。

パラメータの指定

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

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-website-logging-website'

コマンド:

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-website-logging-website-XXXXXXXXXXXX

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

変数の確認:

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-website-logging-website-XXXXXXXXXXXX"
       S3_BUCKET_NAME="${S3_BUCKET_NAME}"

END

手順

S3バケットのWebサイトエンドポイントを取得します。

変数の設定:

S3_BUCKET_WEBSITE_ENDPOINT="${S3_BUCKET_NAME}.s3-website-$( \
    aws s3api get-bucket-location \
      --bucket ${S3_BUCKET_NAME} \
      --output text \
  ).amazonaws.com" \
  && echo ${S3_BUCKET_WEBSITE_ENDPOINT}

結果(例):

handson-cli-s3-website-logging-website-XXXXXXXXXXXX.s3-website-ap-northeast-1.amazonaws.com

注釈

使用しているリージョンに応じて、S3ウェブサイトエンドポイントの形式は以下のいずれかになります。

  • s3-website ダッシュ(-) リージョン: http://bucket-name.s3-website-(リージョン名).amazonaws.com

  • s3-website ドット(.) リージョン: http://bucket-name.s3-website.(リージョン名).amazonaws.com

東京など古めのリージョンは前者になっています。

詳細は、「ウェブサイトエンドポイント」(https://docs.aws.amazon.com/ja_jp/AmazonS3/latest/dev/WebsiteEndpoints.html)を参照してください。

Webサイトにアクセスします。

変数の確認:

cat << ETX

  # S3_BUCKET_WEBSITE_ENDPOINT:"handson-cli-s3-website-logging-website-XXXXXXXXXXXX.s3-website-ap-northeast-1.amazonaws.com"
    S3_BUCKET_WEBSITE_ENDPOINT="${S3_BUCKET_WEBSITE_ENDPOINT}"

ETX

コマンド:

curl ${S3_BUCKET_WEBSITE_ENDPOINT}

結果(例):

<!DOCTYPE html>
<html lang="ja">

<head>
  <meta charset="utf-8">
</head>

<body>
  <h1>JAWS-UG CLI (サンプルコンテンツ)</h1>

  <p>
    <img src="img.jpg" alt="クラウド" />
  </p>
  <p>
    sampleイメージです。
  </p>
</body>
</html>

完了確認

「コンテンツ用S3バケット"handson-cli-s3-website-logging-website-XXXXXXXXXXXX"にコンテンツが存在する。」ことを確認します。

コマンド:

curl -LI -Ss \
  -o /dev/null \
  -w '%{http_code}\n' \
  ${S3_BUCKET_WEBSITE_ENDPOINT}

結果(例):

200

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

環境変数の設定:

export -n AWS_DEFAULT_PROFILE