リソース(Role0)のCloudFormationリソースファイルを作成します。
手順に必要な設定値を変数に格納をします。
1. CloudFormationリソース名
CloudFormationリソース名を指定します。
変数の設定: TEMPLATE_CFN_RESOURCE_NAME='Role0'
変数の設定:
TEMPLATE_CFN_RESOURCE_NAME='Role0'
2. リソースファイル用ディレクトリ
リソースファイル用ディレクトリを指定します。
変数の設定: DIR_TEMPLATE_CFN_RESOURCE="${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources"
DIR_TEMPLATE_CFN_RESOURCE="${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources"
ディレクトリが存在することを確認します。
コマンド: ls -d ${DIR_TEMPLATE_CFN_RESOURCE} 結果(例:存在する場合): ${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources
コマンド:
ls -d ${DIR_TEMPLATE_CFN_RESOURCE}
結果(例:存在する場合):
${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources
存在しない場合は作成します。
コマンド: mkdir -p ${DIR_TEMPLATE_CFN_RESOURCE} 結果(例): (出力なし)
mkdir -p ${DIR_TEMPLATE_CFN_RESOURCE}
結果(例):
(出力なし)
3. リソースファイル名
リソースファイル名を指定します。
変数の設定: FILE_TEMPLATE_CFN_RESOURCE="${DIR_TEMPLATE_CFN_RESOURCE}/${TEMPLATE_CFN_RESOURCE_NAME}.txt" \ && echo ${FILE_TEMPLATE_CFN_RESOURCE} 結果(例): ${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources/Role0.txt
FILE_TEMPLATE_CFN_RESOURCE="${DIR_TEMPLATE_CFN_RESOURCE}/${TEMPLATE_CFN_RESOURCE_NAME}.txt" \ && echo ${FILE_TEMPLATE_CFN_RESOURCE}
${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources/Role0.txt
4. IAMロールパス
IAMロールパスを指定します。
変数の設定: IAM_ROLE_PATH='/handson-cli/'
IAM_ROLE_PATH='/handson-cli/'
5. プリンシパル名
ロールの利用を許可するサービス(ホスト名形式)を指定します。
変数の設定: IAM_ROLE_PRINCIPAL='ec2.amazonaws.com'
IAM_ROLE_PRINCIPAL='ec2.amazonaws.com'
6. IAMロール名サフィックス
IAMロール名のサフィックスを指定します。
変数の設定: IAM_ROLE_NAME_SUFFIX='role'
IAM_ROLE_NAME_SUFFIX='role'
各変数に正しい設定値が格納されていることを確認しながら保存します。
変数の確認: cat << END # 1. TEMPLATE_CFN_RESOURCE_NAME:"Role0" TEMPLATE_CFN_RESOURCE_NAME="${TEMPLATE_CFN_RESOURCE_NAME}" # 2. DIR_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources" DIR_TEMPLATE_CFN_RESOURCE="${DIR_TEMPLATE_CFN_RESOURCE}" # 3. FILE_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources/Role0.txt" FILE_TEMPLATE_CFN_RESOURCE="${FILE_TEMPLATE_CFN_RESOURCE}" # 4. IAM_ROLE_PATH:"/handson-cli/" IAM_ROLE_PATH="${IAM_ROLE_PATH}" # 5. IAM_ROLE_PRINCIPAL:"ec2.amazonaws.com" IAM_ROLE_PRINCIPAL="${IAM_ROLE_PRINCIPAL}" # 6. IAM_ROLE_NAME_SUFFIX:"role" IAM_ROLE_NAME_SUFFIX="${IAM_ROLE_NAME_SUFFIX}" END
変数の確認:
cat << END # 1. TEMPLATE_CFN_RESOURCE_NAME:"Role0" TEMPLATE_CFN_RESOURCE_NAME="${TEMPLATE_CFN_RESOURCE_NAME}" # 2. DIR_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources" DIR_TEMPLATE_CFN_RESOURCE="${DIR_TEMPLATE_CFN_RESOURCE}" # 3. FILE_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources/Role0.txt" FILE_TEMPLATE_CFN_RESOURCE="${FILE_TEMPLATE_CFN_RESOURCE}" # 4. IAM_ROLE_PATH:"/handson-cli/" IAM_ROLE_PATH="${IAM_ROLE_PATH}" # 5. IAM_ROLE_PRINCIPAL:"ec2.amazonaws.com" IAM_ROLE_PRINCIPAL="${IAM_ROLE_PRINCIPAL}" # 6. IAM_ROLE_NAME_SUFFIX:"role" IAM_ROLE_NAME_SUFFIX="${IAM_ROLE_NAME_SUFFIX}" END
下段の変数が入っていない、もしくは上段と同等の値が入っていない場合は、それぞれの手順番号に戻って変数の設定を行います。
CFnリソースファイルを作成します。
変数の確認: cat << END # FILE_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources/Role0.txt" FILE_TEMPLATE_CFN_RESOURCE="${FILE_TEMPLATE_CFN_RESOURCE}" # TEMPLATE_CFN_RESOURCE_NAME:"Role0" TEMPLATE_CFN_RESOURCE_NAME="${TEMPLATE_CFN_RESOURCE_NAME}" # IAM_ROLE_PATH:"/handson-cli/" IAM_ROLE_PATH="${IAM_ROLE_PATH}" # IAM_ROLE_PRINCIPAL:"ec2.amazonaws.com" IAM_ROLE_PRINCIPAL="${IAM_ROLE_PRINCIPAL}" # IAM_ROLE_NAME_SUFFIX:"role" IAM_ROLE_NAME_SUFFIX="${IAM_ROLE_NAME_SUFFIX}" END コマンド: cat << EOF > ${FILE_TEMPLATE_CFN_RESOURCE} ${TEMPLATE_CFN_RESOURCE_NAME}: Type: AWS::IAM::Role Properties: Path: ${IAM_ROLE_PATH} RoleName: !Join - '' - - !Ref AWS::StackName - '-${IAM_ROLE_NAME_SUFFIX}' AssumeRolePolicyDocument: Version: 2012-10-17 Statement: - Effect: Allow Principal: Service: - ${IAM_ROLE_PRINCIPAL} Action: - sts:AssumeRole EOF cat ${FILE_TEMPLATE_CFN_RESOURCE} 結果(例): Role0: Type: AWS::IAM::Role Properties: RoleName: !Join - '' - - !Ref AWS::StackName - '-role' Path: /handson-cli/ AssumeRolePolicyDocument: Version: 2012-10-17 Statement: - Effect: Allow Principal: Service: - ec2.amazonaws.com Action: - sts:AssumeRole
cat << END # FILE_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources/Role0.txt" FILE_TEMPLATE_CFN_RESOURCE="${FILE_TEMPLATE_CFN_RESOURCE}" # TEMPLATE_CFN_RESOURCE_NAME:"Role0" TEMPLATE_CFN_RESOURCE_NAME="${TEMPLATE_CFN_RESOURCE_NAME}" # IAM_ROLE_PATH:"/handson-cli/" IAM_ROLE_PATH="${IAM_ROLE_PATH}" # IAM_ROLE_PRINCIPAL:"ec2.amazonaws.com" IAM_ROLE_PRINCIPAL="${IAM_ROLE_PRINCIPAL}" # IAM_ROLE_NAME_SUFFIX:"role" IAM_ROLE_NAME_SUFFIX="${IAM_ROLE_NAME_SUFFIX}" END
cat << EOF > ${FILE_TEMPLATE_CFN_RESOURCE} ${TEMPLATE_CFN_RESOURCE_NAME}: Type: AWS::IAM::Role Properties: Path: ${IAM_ROLE_PATH} RoleName: !Join - '' - - !Ref AWS::StackName - '-${IAM_ROLE_NAME_SUFFIX}' AssumeRolePolicyDocument: Version: 2012-10-17 Statement: - Effect: Allow Principal: Service: - ${IAM_ROLE_PRINCIPAL} Action: - sts:AssumeRole EOF cat ${FILE_TEMPLATE_CFN_RESOURCE}
Role0: Type: AWS::IAM::Role Properties: RoleName: !Join - '' - - !Ref AWS::StackName - '-role' Path: /handson-cli/ AssumeRolePolicyDocument: Version: 2012-10-17 Statement: - Effect: Allow Principal: Service: - ec2.amazonaws.com Action: - sts:AssumeRole
「リソースファイル"${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources/Role0.txt"が存在する。」ことを確認します。
コマンド: ls ${FILE_TEMPLATE_CFN_RESOURCE} 結果(例): ${HOME}/environment/conf-handson-cli-cfn-ec2-VolumeAttachment/resources/Role0.txt
ls ${FILE_TEMPLATE_CFN_RESOURCE}