0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

EventBridge、AWS Lambda、Amazon SNSで、Lambda定期実行&メール通知を作ってみた

Posted at

概要

こんにちは。
今回は、タイトルにもある通り以下のような内容でリソースを作ってみたので、そのまとめです。
今回はSNS、Lambda、EventBridgeをそれぞれ別々に作成しましたが、Lambdaの作成画面にある「トリガーを追加」からEventBridgeの定期スケジュール実行の作成、「送信先を追加」からSNSのトピック先選択とパブリッシュに必要なIAMロールの自動作成などが行えます。
(それぞれ別で作成した後に気づきました)

作ったもの:

  • EventBridgeスケジューラを使ってLambdaの定期実行
  • Lambdaの関数内で、Amazon SNSトピックにメッセージを送信(パブリッシュ)
  • Amazon SNSからメール通知

きっかけ:
自身で作りたいと思ったシステムを実現する際に、今回作成した構成が必要だったため、そのテストとして作ってみました。
(結局、作りたかったシステムは別の部分で問題があり、作業は止まっていますが…)

参考にさせていただいた記事:

構成図

構成図は以下のようになります。

AWS-qiita-eventbridge-lambda-sns.jpg

実際にやったこと

LambdaとSNSを連携して、Lambdaを実行するとSNSからメールを送信するようにします。
また、そのEventBridgeの定期実行スケジューラにLambdaを登録することで定期的にメール送信を行えるようにしました。

1. SNSトピックの作成

この章では以下のことをやりました。

  1. SNSトピックの作成
  2. サブスクリプションの作成

まず、AWSコンソールの画面から「SNS」と検索し、SNSのサービスを開きます。
SNSの画面から「トピックの作成」をクリックします。

トピックの作成画面で、

  • トピックタイプ
  • 名前
    を入力し、

01-SNSトピック作成.png

ページ下部の「トピックの作成」をクリックします。

02-SNSトピック作成.png

ここまででトピックの作成が完了です。

次にサブスクリプションの作成を行います。
トピックの下にサブスクリプションを登録することで、トピックにパブリッシュされたとき、サブスクリプションに登録したエンドポイントに通知が飛ぶようになります。
SNSサブスクリプション送信先.png

今回は、メール通知をしたいので、「Eメール」を使用します。
トピック作成完了後、以下のような画面が出るので、「サブスクリプションの作成」をクリックします。

03-SNSトピック作成.png

プロトコル→Eメール
エンドポイント→任意のメールアドレス
というように設定し、画面一番下の「サブスクリプションの作成」をクリックします。

04-SNSトピック作成.png

ここで、サブスクリプションの登録確認メールが登録したメールアドレス宛に届きます。
確認メールで確認を行うまでは、サブスクリプションのステータスが「保留中の確認」となっています。
確認メールを開き、「Confirm subscription」をクリックします。

遷移先のブラウザで「Subscription Confirmed」と表示されれば登録完了です。

ブラウザで「Subscription Confirmed」と表示された後、念のため、サブスクリプションのステータスが「確認済み」となっていることを確認します。

サブスクリプションのステータス確認.png

2. Lambda関数の作成とSNSとの連携

この章では以下のことをやりました。

  1. Lambda関数の作成
  2. SNSへのパブリッシュを許可するIAMロール作成
  3. Lambdaへのコードのデプロイ&テスト

Lambda関数の作成

まずは、左上の検索欄に「Lambda」と入力し、Lambdaのダッシュボードに移動します。
「関数の作成」ボタンをクリックし、関数の作成を始めます。

05-Lambda関数ダッシュボード.png

一から作成を選び、関数名を入力します。
今回はPythonコードでSNSへのメール送信を行うので、ランタイムにはPythonを選択します。

05-Lambda作成.png

ほかの項目はそのままに、画面下の「関数を作成」ボタンをクリックして関数を作成します。

そうすることでLambda関数の作成が行えます。

07-Lambda作成完了.png

SNSへのパブリッシュを許可するIAMロール作成

次に、SNSへのパブリッシュを許可するIAMロールを作成していきます。
今回はIAMロールを自身で作成する方法で進めました。
最初にも記載しましたが、Lambdaの関数画面にある「送信先を追加」を使うことで簡単にSNSトピックとの連携ができます。
(Lambdaの関数画面にある「送信先を追加」から先ほど作成したSNSトピックを指定し、アクセス権限で「必要なアクセス許可を追加」を選択することで、LambdaからSNSにパブリッシュするためのIAMロールが自動的に付与されます。)

では実際にIAMロールを作成していきます。

まずは先ほど作成したLambda関数に付与されているIAMロールの編集画面に遷移します。
タブから「設定」を選択し、サイドバーから「アクセス権限」を選択します。
そして、ロール名をクリック(画像のsns-test-role-7817uabeの部分)します。

07-IAMロール作成画面遷移.png

クリックすると、そのIAMロールの画面に遷移します。
ここで「許可を追加」をクリックし、「ポリシーをアタッチ」を選択します。

08-許可を追加.png

LambdaからSNSトピックへのパブリッシュを許可するポリシーである「AWSLambdaSNSTopicDestinationExecutionRole」を追加します。
(もう一つのポリシーは、LambdaがCloudWatch Logsにログを出力するための最低限の権限を持つデフォルトのIAMポリシーです。関数作成時にデフォルトの実行ロールで自動付与を選択するとこのポリシーを含んだロールが付与されます。)
09-IAM.png

これでIAMロールの作成が完了です。

Lambdaへのコードのデプロイ&テスト

続いて、Lambdaにコードをデプロイしていきます。
先ほど作成したLambdaを開き、赤枠の部分のコードタブからコードソースをデプロイしていきます。

10-Lambdaのコード.png

今回は以下のコードをデプロイしていきます。
TopicArnには、先ほど作成したSNSトピックのARNを入力してください

lambda_function.py
import boto3
client = boto3.client('sns')

def lambda_handler(event, context):
    
    params = {
    'TopicArn': '{先ほど作成したSNSのARN}',
    'Subject': 'SNSからメールを送信',
    'Message': 'メールを送信\nテスト'
    }
    
    client.publish(**params)

コードを載せたら、以下の画像のボタンからデプロイをします。
SNSトピックのARNの部分の修正やデプロイを忘れると正しく動作しないので気を付けてください。

11-Lambdaデプロイ.png

最後に、Lambdaを実際に動かしてメールが送信されるかどうかをテストします。

画像のように「テスト」タブを開き、任意の「イベント名」を入力した後、「テスト」ボタンをクリックします。

12-Lambdaテスト.png

メールが届けば作業完了です。
届かない場合は、以下の点を確認してみてください。

  • SNSサブスクリプションのステータスは「確認済み」となっているか
  • Lambdaに添付したIAMロールのポリシーが正しいか
  • LambdaのコードにSNSトピックのARNが記載されているか
  • Lambdaにコードをデプロイしたか

3. EventBridgeスケジューラを使ってLambdaの定期実行

この章では以下のことをやりました。

  1. EventBridgeのスケジュール作成

EventBridgeのスケジュール作成

Lambdaを定期的に呼び出すために、EventBridgeのスケジュールを作成していきます。

まずはAWSコンソールの検索欄から「EventBridge」と検索し、EventBridgeを開きます。

13-EventBridge初期画面.png

サイドバーの「スケジュール」を選択し、開かれた画面で「スケジュールを作成」をクリックします。

14-EventBridgeスケジュールを作成.png

「スケジュールの詳細の指定」画面で、それぞれ必要な項目を入力していきます。

  • スケジュール名
  • 頻度
    • 今回は「rateベースのスケジュール」を指定
  • rate式
    • スケジュールを実行する間隔
  • フレックスタイムウィンドウ
    • 今回はオフを指定
  • 開始日時・終了日時

15-1-EventBridgeスケジュール名入力.png

15-EventBridgeスケジュールパターン指定.png

16-EventBridgeフレックスウィンドウと時間枠指定.png

ここまで入力ができたら「次へ」ボタンをクリックします。

次はターゲットの選択です。
Lambdaを呼び出し先として設定します。
「テンプレート化されたターゲット」からLambdaを指定します。
17-EventBridgeターゲットでLambda指定.png

そして、先ほど作成したLambda関数を指定します。
今回はLambdaへの入力は特にないのでペイロード派からのままにしています。

18-EventBridge呼び出すLambda選択.png

次の「設定-オプション」ページでは、スケジュール完了後のアクションとして「DELETE」を選択し、最後の呼び出しが完了した後スケジュールを削除するようにします。(消さないこともできる)

そして、ほかの項目はそのままに「スケジュールを作成」ボタンをクリックします。

19-EventBridgeDeleteのみ指定.png

20-EventBridgeスケジュール作成完了ボタン.png

そうすることで、スケジュールの作成が完了します。

21-EventBridgeスケジュール作成完了.png

ここまでで、EventBridgeからLambdaを呼び出し、LambdaからSNSにメールを出すよう通知するという処理が完成です。

まとめ

今回はEventBridge、Lambda、SNSを使用して、メールの定期送信という機能を作成しました。
実際に作ったのは初めてですが、資格を勉強していたことである程度の作業イメージが付きました。
ただし、実際に触ってみてわかったこと(さらに簡単に作るための機能、どのような設定が可能かなど)もあるのでやってみてよかったと感じました。
今後も気になることがあればどんどん触るようにしたいと思います。
わからない点、間違っている点等あればコメントで教えてください。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?