ハンズオン(簡易版): S3入門 - ハイレベルコマンド活用

2.7. S3オブジェクトの移動 (ハイレベルコマンド)

手順の目的

移動元S3バケット"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"に存在するオブジェクト"beta/1.txt"を、移動先S3バケット"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"のオブジェクト"charlie/2.txt"として移動します。

設定値の指定

設定値の指定

手順に必要な設定値を変数に格納をします。

1. 移動元S3バケット名

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

変数の設定:

S3_BUCKET_PREFIX_SOURCE='handson-cli-s3-1st-highlevel'

コマンド:

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

結果(例):

XXXXXXXXXXXX

変数の設定:

S3_BUCKET_SOURCE="${S3_BUCKET_PREFIX_SOURCE}-${aws_id}" \
  && echo ${S3_BUCKET_SOURCE}

結果(例):

handson-cli-s3-1st-highlevel-XXXXXXXXXXXX

2. 移動元S3オブジェクトキー

移動元S3オブジェクトキーを指定します。

変数の設定:

S3_OBJECT_SOURCE='beta/1.txt'

3. 移動先S3バケット名

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

変数の設定:

S3_BUCKET_PREFIX='handson-cli-s3-1st-highlevel'

コマンド:

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-1st-highlevel-XXXXXXXXXXXX

4. 移動先S3オブジェクトキー

移動先S3オブジェクトキーを指定します。

変数の設定:

S3_OBJECT_KEY='charlie/2.txt'

設定値の確認

各変数に正しい設定値が格納されていることを確認します。

変数の確認:

cat << END

  # 1. S3_BUCKET_SOURCE:"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"
       S3_BUCKET_SOURCE="${S3_BUCKET_SOURCE}"
  # 2. S3_OBJECT_SOURCE:"beta/1.txt"
       S3_OBJECT_SOURCE="${S3_OBJECT_SOURCE}"
  # 3. S3_BUCKET_NAME:"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"
       S3_BUCKET_NAME="${S3_BUCKET_NAME}"
  # 4. S3_OBJECT_KEY:"charlie/2.txt"
       S3_OBJECT_KEY="${S3_OBJECT_KEY}"

END

下段の変数が入っていない、もしくは上段と同等の値が入っていない場合は、それぞれの手順番号に戻って変数の設定を行います。

処理の実行

S3オブジェクトを移動します。

変数の確認:

cat << END

  # S3_BUCKET_SOURCE:"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"
    S3_BUCKET_SOURCE="${S3_BUCKET_SOURCE}"
  # S3_OBJECT_SOURCE:"beta/1.txt"
    S3_OBJECT_SOURCE="${S3_OBJECT_SOURCE}"
  # S3_BUCKET_NAME:"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"
    S3_BUCKET_NAME="${S3_BUCKET_NAME}"
  # S3_OBJECT_KEY:"charlie/2.txt"
    S3_OBJECT_KEY="${S3_OBJECT_KEY}"

END

コマンド:

aws s3 mv s3://${S3_BUCKET_SOURCE}/${S3_OBJECT_SOURCE} \
  s3://${S3_BUCKET_NAME}/${S3_OBJECT_KEY}

結果(例):

move: s3://handson-cli-s3-1st-highlevel-XXXXXXXXXXXX/handson-cli-s3-1st-highlevel-XXXXXXXXXXXX to s3://handson-cli-s3-1st-highlevel-XXXXXXXXXXXX/charlie/2.txt

完了確認

「S3バケット"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"にオブジェクト"charlie/2.txt"が存在する。」ことを確認します。

コマンド:

aws s3 ls s3://${S3_BUCKET_NAME} --recursive \
  | grep ${S3_OBJECT_KEY} \
  | awk '{print $4}'

結果(例):

charlie/2.txt

手順の完了

(参考) マネジメントコンソールの確認

  • 左ペインの"バケット"をクリックします。

バケット一覧(画面)

  • 検索欄にバケット名"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"を入力します。

  • バケット名"handson-cli-s3-1st-highlevel-XXXXXXXXXXXX"(リンク)をクリックします。

バケット詳細画面

  • "オブジェクト"タブを表示します。