1
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?

More than 3 years have passed since last update.

CloudTrailとCloudWatchLogsを使用してIAM関連イベントの通知

Posted at

エンタメ系企業の社内もろもろを担当しているakibinです。

最近はハマっているSummer FeelingsのPVがシティ・ポップぽくていい感じ。あー遊びに行きたいよ早くワクチン打たせてくれ!(年代バレる)

やりたいこと

IAM関連の操作がされた場合にメール通知してほしいと思いました。
IAM関連の作業はセキュリティインシデントに直結しますが、複数人で管理者やってる場合や、SDKの作業でどうしても開発者がIAMロールいじらないといけない場合など、念の為どんな作業してるか把握するためです。

これを実現するのにCloudTrailの証跡を作成する必要があり、証跡はS3に保存されるので、S3への保存費用が発生します。

作業の流れ

  • CloudTrailに証跡を作成
    • それ用のCloudWatchLogsも同時に作成
  • CloudWatchLogsでメトリクスフィルターを設定
  • 作成したメトリクスフィルターにアラートを設定

前提条件

Amazon SNSでメール通知用の設定がされている前提です。設定したことが無い方は以下の記事がわかりやすいので参照して作成してください。
[基本操作]Amazon SNSでメールを送信する

CloudTrailに証跡を作成(それ用のCloudWatchLogsも同時に作成)

  1. CloudTrail > [証跡] > [証跡の作成]をクリック
  2. [全般的な詳細]を入力
    • 証跡名:任意の名前
    • ストレージの場所:今回は新しいS3を作成
    • ログファイルのSSE-KMS暗号化:今回はなし(必要であれば暗号化実施してください)
    • ログファイルの検証:有効
    • SNS通知の配信:なし(SNSとの紐付けはCloudWatchLogsで実施します)
      スクリーンショット 2021-07-15 15.03.24.png
  3. CloudWatch Logsにチェック
    • ロググループ、IAMロールはどちらも新規に作成、任意の名前を入れる
      スクリーンショット 2021-07-15 15.15.07.png
  4. 次に進んで、[ログイベントを選択]
    • IAM関連の操作のみが対象なので、今回は管理イベントのみでOKです。
    • 管理イベントのAPIアクティビティはデフォルトの[読み取り]と[書き込み]でOK
      スクリーンショット 2021-07-15 15.17.04.png
  5. 次に進んで、[確認と作成]で内容を確認して[証跡を作成]

CloudWatckLogsでメトリクスフィルターを設定

  1. 先程CloudTrailで作成したロググループを開き、[メトリクスフィルター]から[メトリクスフィルターを作成]をクリック
    スクリーンショット 2021-07-15 18.50.23.png
  2. [パターン定義]のフィルターパターンに{ $.eventSource = "iam.amazonaws.com" }を入力して[Next]
    スクリーンショット 2021-07-15 19.00.17.png
  3. [メトリクスの割り当て]で各項目を入力して[Next]
    • フィルター名(任意の名前):IAM_Changes
    • メトリクス名前空間(任意の名前):CloudTrailMetrics
    • メトリクス値:1
    • デフォルト値:0
      スクリーンショット 2021-07-15 19.07.21.png
  4. 設定内容を確認して[メトリクスフィルターを作成]
    スクリーンショット 2021-07-15 19.12.17.png

作成したメトリクスフィルターにアラートを設定

  1. 作成したメトリクスフィルターにチェックを入れ、[アラームを作成]
    スクリーンショット 2021-07-15 19.17.25.png

  2. デフォルト以外は以下を設定して[次へ]

    • 統計:最大
    • しきい値:0
    • 欠落データの処理:欠落データを適性として処理
      スクリーンショット 2021-07-15 20.07.40.png
  3. [アクションの設定]で事前に作成したSNSを選択して[次へ]
    スクリーンショット 2021-07-15 19.25.43.png

  4. 任意の[アラーム名]を入力して[次へ]
    スクリーンショット 2021-07-15 19.29.12.png

  5. プレビューを確認、問題なければ[アラームの作成]

スクリーンショット 2021-07-15 19.31.07.png

動作確認

試しにIAMユーザを作成。
スクリーンショット 2021-07-15 19.34.49.png

きっちりアラームがメールで飛んできました!
スクリーンショット 2021-07-15 19.59.51.png

おまけ?

ちなみに、CloudCloudWatchEventsでもCloudTrailと連携してEC2関連のイベントとかの通知が可能なようですが、サービス名にIAMを選択できなかったので、IAM関連はいけないっぽい?なので、今回はCloudWatchLogsと連携で設定しました。もしEventsでも可能という方、教えてください!
スクリーンショット 2021-07-15 15.24.57.png

こちらもチェックお願いします!

Twitterアカウント
Youtubeチャンネル

1
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
1
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?