AWS CloudFormationを触ってみる #1
もくじ
はじめに
こんにちは 中村です!
業務でCloudFormation扱う機会が少ないので、自分で触ってみることにしました!
CloudFormationとは
公式によると以下の通り
AWS CloudFormation は、インフラストラクチャをコードとして扱うことで、AWS およびサードパーティーの> リソースをモデル化、プロビジョニング、管理することができます。
動画で見るとイメージしやすいですね
同じようなリソースを何度も作成する必要がある場合に迅速でミスなく作れちゃうのがメリットかと思います!
テンプレートファイルを書くのは大変ではありますが!
手順
テンプレート作成
以下のテンプレートを保存します
とりあえずCloudFormationを触ってみるだけなので、簡単そうなSNSを作ってみます
Parameters:
Email:
Type: String
AWSTemplateFormatVersion: 2010-09-09
Resources:
CarSalesTopic:
Type: AWS::SNS::Topic
Properties:
DisplayName: test-sns
TopicName: test-sns
Subscription:
- Endpoint: !Ref Email
Protocol: email
CloudFormation スタックを作成
AWSマネジメントコンソールにてCloudFormationの画面を開き、
「スタックの作成」をクリックする
![](https://storage.googleapis.com/zenn-user-upload/186e42067f15-20220522.png)
「テンプレートファイル」のアップロードを選択する
「ファイルの選択」をクリックする
![](https://storage.googleapis.com/zenn-user-upload/523dfa7ca5dc-20220522.png)
先ほど保存したテンプレートファイルを選択する
![](https://storage.googleapis.com/zenn-user-upload/5e713a0d99b7-20220522.png)
「次へ」すすむ
![](https://storage.googleapis.com/zenn-user-upload/f6729df2c5cc-20220522.png)
お好みの「スタックの名前」を入力する
パラメータを入力する ※今回のテンプレートではSNSの宛先になるメールアドレスを入力します
「次へ」すすむ
![](https://storage.googleapis.com/zenn-user-upload/04981e9ba05b-20220522.png)
「パラメータ」は、テンプレートファイルにて自由に定義する事ができます
定義したパラメータを使ってリソース名や設定内容をスタックごとに変更する事ができますね!
今回はSNSから送る宛先のメールアドレスを変えられるように設定しました!
![](https://storage.googleapis.com/zenn-user-upload/9dd00167cc9a-20220522.png)
次の画面は特に入力不要
画面下部へスクロールし、「次へ」すすむ
![](https://storage.googleapis.com/zenn-user-upload/680cf33a79c4-20220522.png)
設定内容のプレビュー画面が表示されます。
内容が問題なければ画面下部の「スタックの作成」をクリックする
![](https://storage.googleapis.com/zenn-user-upload/57b9071acb4f-20220522.png)
「CREATE_IN_PROGRESS」なので、今作成中です。しばしお待ちを。
![](https://storage.googleapis.com/zenn-user-upload/9fa59e947c4a-20220522.png)
「CREATE_COMPLETE」と表示されれば完了です
![](https://storage.googleapis.com/zenn-user-upload/9338291ecf97-20220522.png)
ちゃんと作成されたか確認
- リソースタブをクリックすると、作成されたリソースが確認できます
- ARNをクリックすると作成されたリソースの画面へ飛ぶことができます
![](https://storage.googleapis.com/zenn-user-upload/607504b65caf-20220522.png)
SNSが作成されていますね
![](https://storage.googleapis.com/zenn-user-upload/e1add0665fbd-20220522.png)
動作確認
SNSではサブスクリプション作成時に宛先のメールアドレスが「承認」しないとメールが送れません
![](https://storage.googleapis.com/zenn-user-upload/44d37a3f0a7a-20220522.png)
設定したメールアドレスに届いているメールを確認し、
「Confirm subscription」をクリックてサブスクリプションを承認します。
![](https://storage.googleapis.com/zenn-user-upload/2d5281de2099-20220522.png)
「保留流の確認」から「確認済み」に変わりました。これでメールを送る事ができます
![](https://storage.googleapis.com/zenn-user-upload/3a5c7e973c03-20220522.png)
メールを送ってみましょう。「メッセージの発行」をクリックします
![](https://storage.googleapis.com/zenn-user-upload/9b9b6e541bb5-20220522.png)
適当に文字を入力します
![](https://storage.googleapis.com/zenn-user-upload/79d69d350851-20220522.png)
「メッセージの発行」をクリックします
![](https://storage.googleapis.com/zenn-user-upload/291b65bfedcf-20220522.png)
ちゃんとメールが届きました
![](https://storage.googleapis.com/zenn-user-upload/035370705741-20220522.png)
テンプレートファイルの書き方について
最初に紹介したテンプレートファイルですが、CloudFormationユーザーガイドと睨めっこしながら書きました。
左メニューから
「Template reference」 → 「Resource and property reference」と進みます
![](https://storage.googleapis.com/zenn-user-upload/7c3b6bb477e9-20220528.png)
するとAWSサービスの一覧がズラーっと出てくるので…
![](https://storage.googleapis.com/zenn-user-upload/63db0710cde2-20220528.png)
作成したいサービスを探します
![](https://storage.googleapis.com/zenn-user-upload/359745c4eb37-20220528.png)
今回はSNSトピックを作成しようとしているので「AWS::SNS::Topic」をクリックする
![](https://storage.googleapis.com/zenn-user-upload/d3dc0eb11a99-20220528.png)
あとは出てきたページとひたすら睨めっこします (; ・ Д ・ )
全部英語ですが、気合いでどうにかします (; ・ Д ・ )
所感
所感
1つのリソースだけだとymlファイルは短くて済みますが、本来の業務で使うようなツールはもっと色々なリソースを作成するので、もっと長くなるかと思います。なので、もっと公式のリファレンスと仲良くなってymlの書き方にも慣れていく必要があると感じました。頑張るぞっ
ベンジャミンのサーバレス開発サービス
ベンジャミンではAWS Lambdaを使ったサーバーレス開発サービスを提供しております。詳細は以下リンクをご確認ください