はじめに
SOAの資格試験対策のために学んだことを記録として残します。
SOAの試験は、C02に改訂されてからマネジメントコンソールで回答する問題も追加され、ハンズオンで学習することが今まで以上に重要となりました。
この記事では、実際にEventBridgeを動かして使い方を説明します。
EventBridgeとは?
状態の変化(イベント)に対し、あらかじめ設定したルールに基づいて、ターゲット(他のAWSサービスなど)に対して何らかのアクションを実行させるサービスです。
イベントは、AWS Config、CloudWatch、CloudTrailなどによって検知されます。
今回はEC2インスタンスの状態変化を検知して、SNSを起動し、メール通知を行うという仕組みを構築します。
手順
- EC2インスタンスの作成
- SNSトピック/サブスクリプションの作成
- EventBridgeの作成
- 実行
1. EC2インスタンスの作成
テスト用に適当なインスタンスを作成しておきます。
インスタンスは停止したり、終了したりするために作成するだけなのでデフォルト設定でOKです。
- OS:Amazon Linux 2
- インスタンスタイプ:t2.micro、
- キーペア:なし
2. SNSトピック/サブスクリプションの作成
ここでは、Eメールでの通知設定を行います。
まずはSNSトピックを作成します。SNSのコンソール画面から「トピック」を選択して、「トピックの作成」を行います。
トピック名は任意の名前を入力しておきます。
トピックの名前だけ入力し、あとはデフォルト設定のままにします。
トピック作成後、「サブスクリプション」を選択し、「サブスクリプションの作成」を行います。
サブスクリプションの設定画面で次のように設定します。それ以外は特に設定しません。
- トピックARN:先ほど作成したトピックを選択
- プロトコル:Eメール
- エンドポイント:送信先のメールアドレス
サブスクリプション作成後、指定したアドレスに確認メールが届くので、Confirm Subscriptionを押して認証します。
認証すると、Subscription confirmedというメッセージが表示されます。
設定内容を確認しておきます。
3. EventBridgeの作成
マネジメントコンソールからEventBridgeの画面に移動し、「ルール」の選択→「ルールの作成」をクリックします。
ルールの設定画面で任意のルール名を設定します。
イベントバスはデフォルト、ルールタイプは「イベントパターンを持つルールタイプ」を選択します。
イベントパターンの設定画面で以下のように設定します。
続いて、ターゲットの設定画面でターゲットタイプを「AWSのサービス」を選択します。
ターゲットに「SNSトピック」を選択し、トピックは上で作成したSNSトピックを選びます。
後の設定は全てデフォルトのままでOKです。
上記の設定をしたら、「ルールの作成」をクリックして作成します。
4. 実行
EventBridgeがEC2インスタンスの状態変化を検知できているか確認してみます。
EC2インスタンスの一覧画面から作成したインスタンスを選択し、インスタンスを停止(終了でも可)します。
すると、インスタンスの状態が「stopped」に変更されます。
インスタンスが停止されたら、SNSでエンドポイントに指定したアドレスを確認してください。
以下のように、インスタンスの状態が停止になったことを通知するメールが届いていれば成功となります。
試したあとは、インスタンスやSNSトピック、EventBridgeのルールを削除しておきましょう。
まとめ
EventBridgeを利用することで、あるイベントの発生をトリガーとして、さまざまなAWSサービスを起動させることができます。
今回の例ではSNSからのメール通知を行いましたが、例えばEC2インスタンスの状態がterminatedになったら、Lambdaを起動してインスタンスを再起動するという仕組みを構築することもできます。
このように、EventBridgeを利用することで運用にまつわる作業を自動化することができます。