リソース(SecurityGroup0)のCloudFormationリソースファイルを作成します。
手順に必要な設定値を変数に格納をします。
1. CloudFormationリソース名
CloudFormationリソース名を指定します。
変数の設定: TEMPLATE_CFN_RESOURCE_NAME='SecurityGroup0'
変数の設定:
TEMPLATE_CFN_RESOURCE_NAME='SecurityGroup0'
2. リソースファイル用ディレクトリ
リソースファイル用ディレクトリを指定します。
変数の設定: DIR_TEMPLATE_CFN_RESOURCE="${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources"
DIR_TEMPLATE_CFN_RESOURCE="${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources"
ディレクトリが存在することを確認します。
コマンド: ls -d ${DIR_TEMPLATE_CFN_RESOURCE} 結果(例:存在する場合): ${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources
コマンド:
ls -d ${DIR_TEMPLATE_CFN_RESOURCE}
結果(例:存在する場合):
${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/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-Instance/resources/SecurityGroup0.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-Instance/resources/SecurityGroup0.txt
4. VPCのリソース名
VPCのリソース名の指定します。
変数の設定: TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC='Vpc0'
TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC='Vpc0'
5. セキュリティグループの説明
セキュリティグループの説明を指定します。
変数の設定: EC2_SECURITY_GROUP_DESCRIPTION='for handson-cli-cfn-ec2-Instance.'
EC2_SECURITY_GROUP_DESCRIPTION='for handson-cli-cfn-ec2-Instance.'
6. セキュリティグループ名サフィックス
セキュリティグループ名のサフィックスを指定します。
変数の設定: EC2_SECURITY_GROUP_NAME_SUFFIX='sg'
EC2_SECURITY_GROUP_NAME_SUFFIX='sg'
各変数に正しい設定値が格納されていることを確認しながら保存します。
変数の確認: cat << END # 1. TEMPLATE_CFN_RESOURCE_NAME:"SecurityGroup0" TEMPLATE_CFN_RESOURCE_NAME="${TEMPLATE_CFN_RESOURCE_NAME}" # 2. DIR_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources" DIR_TEMPLATE_CFN_RESOURCE="${DIR_TEMPLATE_CFN_RESOURCE}" # 3. FILE_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources/SecurityGroup0.txt" FILE_TEMPLATE_CFN_RESOURCE="${FILE_TEMPLATE_CFN_RESOURCE}" # 4. TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC:"Vpc0" TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC="${TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC}" # 5. EC2_SECURITY_GROUP_DESCRIPTION:"for handson-cli-cfn-ec2-Instance." EC2_SECURITY_GROUP_DESCRIPTION="${EC2_SECURITY_GROUP_DESCRIPTION}" # 6. EC2_SECURITY_GROUP_NAME_SUFFIX:"sg" EC2_SECURITY_GROUP_NAME_SUFFIX="${EC2_SECURITY_GROUP_NAME_SUFFIX}" END
変数の確認:
cat << END # 1. TEMPLATE_CFN_RESOURCE_NAME:"SecurityGroup0" TEMPLATE_CFN_RESOURCE_NAME="${TEMPLATE_CFN_RESOURCE_NAME}" # 2. DIR_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources" DIR_TEMPLATE_CFN_RESOURCE="${DIR_TEMPLATE_CFN_RESOURCE}" # 3. FILE_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources/SecurityGroup0.txt" FILE_TEMPLATE_CFN_RESOURCE="${FILE_TEMPLATE_CFN_RESOURCE}" # 4. TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC:"Vpc0" TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC="${TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC}" # 5. EC2_SECURITY_GROUP_DESCRIPTION:"for handson-cli-cfn-ec2-Instance." EC2_SECURITY_GROUP_DESCRIPTION="${EC2_SECURITY_GROUP_DESCRIPTION}" # 6. EC2_SECURITY_GROUP_NAME_SUFFIX:"sg" EC2_SECURITY_GROUP_NAME_SUFFIX="${EC2_SECURITY_GROUP_NAME_SUFFIX}" END
下段の変数が入っていない、もしくは上段と同等の値が入っていない場合は、それぞれの手順番号に戻って変数の設定を行います。
CFnリソースファイルを作成します。
変数の確認: cat << END # FILE_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources/SecurityGroup0.txt" FILE_TEMPLATE_CFN_RESOURCE="${FILE_TEMPLATE_CFN_RESOURCE}" # TEMPLATE_CFN_RESOURCE_NAME:"SecurityGroup0" TEMPLATE_CFN_RESOURCE_NAME="${TEMPLATE_CFN_RESOURCE_NAME}" # TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC:"Vpc0" TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC="${TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC}" # EC2_SECURITY_GROUP_DESCRIPTION:"for handson-cli-cfn-ec2-Instance." EC2_SECURITY_GROUP_DESCRIPTION="${EC2_SECURITY_GROUP_DESCRIPTION}" # EC2_SECURITY_GROUP_NAME_SUFFIX:"sg" EC2_SECURITY_GROUP_NAME_SUFFIX="${EC2_SECURITY_GROUP_NAME_SUFFIX}" END コマンド: cat << EOF > ${FILE_TEMPLATE_CFN_RESOURCE} ${TEMPLATE_CFN_RESOURCE_NAME}: Type: AWS::EC2::SecurityGroup Properties: VpcId: !Ref ${TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC} GroupDescription: ${EC2_SECURITY_GROUP_DESCRIPTION} GroupName: !Join - '' - - !Ref AWS::StackName - '-${EC2_SECURITY_GROUP_NAME_SUFFIX}' EOF cat ${FILE_TEMPLATE_CFN_RESOURCE} 結果(例): SecurityGroup0: Type: AWS::EC2::SecurityGroup Properties: VpcId: !Ref Vpc0 GroupDescription: for handson-cli-cfn-ec2-Instance. GroupName: !Join - '' - - !Ref AWS::StackName - '-sg'
cat << END # FILE_TEMPLATE_CFN_RESOURCE:"${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources/SecurityGroup0.txt" FILE_TEMPLATE_CFN_RESOURCE="${FILE_TEMPLATE_CFN_RESOURCE}" # TEMPLATE_CFN_RESOURCE_NAME:"SecurityGroup0" TEMPLATE_CFN_RESOURCE_NAME="${TEMPLATE_CFN_RESOURCE_NAME}" # TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC:"Vpc0" TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC="${TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC}" # EC2_SECURITY_GROUP_DESCRIPTION:"for handson-cli-cfn-ec2-Instance." EC2_SECURITY_GROUP_DESCRIPTION="${EC2_SECURITY_GROUP_DESCRIPTION}" # EC2_SECURITY_GROUP_NAME_SUFFIX:"sg" EC2_SECURITY_GROUP_NAME_SUFFIX="${EC2_SECURITY_GROUP_NAME_SUFFIX}" END
cat << EOF > ${FILE_TEMPLATE_CFN_RESOURCE} ${TEMPLATE_CFN_RESOURCE_NAME}: Type: AWS::EC2::SecurityGroup Properties: VpcId: !Ref ${TEMPLATE_CFN_RESOURCE_NAME_EC2_VPC} GroupDescription: ${EC2_SECURITY_GROUP_DESCRIPTION} GroupName: !Join - '' - - !Ref AWS::StackName - '-${EC2_SECURITY_GROUP_NAME_SUFFIX}' EOF cat ${FILE_TEMPLATE_CFN_RESOURCE}
SecurityGroup0: Type: AWS::EC2::SecurityGroup Properties: VpcId: !Ref Vpc0 GroupDescription: for handson-cli-cfn-ec2-Instance. GroupName: !Join - '' - - !Ref AWS::StackName - '-sg'
「リソースファイル"${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources/SecurityGroup0.txt"が存在する。」ことを確認します。
コマンド: ls ${FILE_TEMPLATE_CFN_RESOURCE} 結果(例): ${HOME}/environment/conf-handson-cli-cfn-ec2-Instance/resources/SecurityGroup0.txt
ls ${FILE_TEMPLATE_CFN_RESOURCE}