SIEM on Amazon OpenSearch Serviceを構築
このブログまわりのモニタリングをSIEM on Amazon OpenSearch Serviceでやってみようと構築してみました。
https://github.com/aws-samples/siem-on-amazon-opensearch-serviceのCloudFormationテンプレートを使用しました。
目次
MaxMindの無料ライセンスの取得
IPアドレスの国情報、緯度経度の情報を使用するためにMaxMind社のGeoLite2 Freeを使用しています。
スタック作成時に無料ライセンスキーが必要ですので先に取得しておきました。
https://www.maxmind.com/en/homeにアクセスして、[Products]-[GeoLite2 Free Geolocation Data]を選択しました。
[Sign Up for GeoLite2]を選択しました。
必要事項を入力して送信しました。
入力したメールアドレスにURL付きのメールが送信されたのでクリックしてアカウントを作成しました。
ログインした後、[Manage License Keys]の[Create new license key]ボタンを押下しました。
License key descriptionに説明を入力して、デフォルトのまま[Confirm]を押下したらライセンスキーが発行されました。
CloudFormationスタックの作成
Githubページに戻ってクイックスタートから、大阪リージョンの[Launch Stack]を選択しました。
理由はブログのリソースが大阪リージョンだからです。
スタックのパラメータ、GeoLite2LicenseKeyに発行済のキーを入力しました。
AllowedSourceIPAddressesには、OpenSearch Dashboardにアクセスする送信元IPアドレス範囲を指定します。
後で、OpenSearch Serviceのポリシーで変更もできます。
スタック作成後、20分ほどでスタック作成が完了しました。
作成されたもの(見落としがあるかもですが)
SQSキュー
- aes-siem-dlq
- aes-siem-sqs-splitted-logs
OpenSearch Serviceドメイン
- aes-siem
SNSトピック
- aes-siem-alert
S3バケット
- aes-siem-123456789012-log
- aes-siem-123456789012-geo
- aes-siem-123456789012-snapshot
aes-siem-123456789012-logのUserLogs/プレフィックスに格納したログオブジェクトがLamda関数aes-siem-es-loaderによって、OpenSearch Serviceに保存されていました。
Lambda関数
- aes-siem-es-loader-stopper
- aes-siem-index-metrics-exporter
- aes-siem-es-loader
- aes-siem-configure-aes
- aes-siem-deploy-aes
- aes-siem-geoip-downloader
- siem-BucketNotificationsHandlerxxxxxxxxxxxxxx
aes-siem-es-loaderによってログがS3からOpenSearch Serviceに保存されていました。
他のS3バケットをソースにするならイベント追加で指定すればよさそうです。
CloudWatchアラーム
- siem-TotalFreeStorageSpaceRemainsLowAlarmxxxxxxx
KMS CMK
- aes-siem-key
EventBridgeルール
- siem-CwlRuleLambdaGeoipDownloaderxxxxxxxx
- siem-EsLoaderStopperRulexxxxxxxxxxx
- siem-EventBridgeRuleLambdaMetricsExporterxxxxxxxxx
IAMロール
- aes-siem-deploy-role-for-lambda
- aes-siem-es-loader-for-ec2
- aes-siem-snapshot-role
- aes-siem-sns-role
- siem-BucketNotificationsHandlerxxxxxxx
- siem-LambdaEsLoaderServiceRolexxxxxxxxx
- siem-LambdaEsLoaderStopperServiceRolexxxxxxxxx
- siem-LambdaGeoipDownloaderServiceRolexxxxxxxxxxxx
- siem-LambdaMetricsExporterServiceRolexxxxxxxxxxx
ログの収集
今後増やしてダッシュボードを調整するとして、とりあえずCloudFrontのログを収集してみました。
CloudFrontディストリビューションでバケットを設定しました。
プレフィックスにUserLogs/を入れなかったので、Lambda関数のイベントを追加しました。
Dashboardの設定
SIEM on Amazon OpenSearch Service Workshop 2.5. SIEM Settingsのインポートオブジェクトをダウンロードしました。
ダウンロードリンクはこちらでした。
https://aes-siem.s3.ap-northeast-1.amazonaws.com/assets/saved_objects.zip
ダウンロードした後展開しました。
CloudFormationスタックの出力からDashboardのURLにアクセスしました。
ログインユーザーと初期パスワードもスタックの出力にありました。
テナント選択は1人でしか使わないので、Privateにしました。
左ペインの[Stak Management]を選択しました。
[Saved Objects]を選択しました。
右上の[Import]を押下しました。
ダウンロードしたzipファイルを展開して、dashboard.ndjsonをインポートしました。
Dashboardのオブジェクトがインポートされました。
DashboardメニューからCloudFront Summaryを見てみました。
CloudFrontアクセスログを可視化したダッシュボードが表示されました。
今後、WAFや、ALB、S3、CloudTrailなども可視化していきます。
最後までお読みいただきましてありがとうございました!
【PR】 「AWS認定試験対策 AWS クラウドプラクティショナー」という本を書きました。
【PR】 「AWSではじめるLinux入門ガイド」という本を書きました。
【PR】 「ポケットスタディ AWS認定 デベロッパーアソシエイト」という本を書きました。
【PR】 「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル」という本を書きました。

開発ベンダー5年、ユーザ企業システム部門通算9年、ITインストラクター5年目でプロトタイプビルダーもやりだしたSoftware Engineerです。
質問はコメントかSNSなどからお気軽にどうぞ。
出来る限りなるべく答えます。
このブログの内容/発言の一切は個人の見解であり、所属する組織とは関係ありません。
このブログは経験したことなどの共有を目的としており、手順や結果などを保証するものではありません。
ご参考にされる際は、読者様自身のご判断にてご対応をお願いいたします。
また、勉強会やイベントのレポートは自分が気になったことをメモしたり、聞いて思ったことを書いていますので、登壇者の意見や発表内容ではありません。
ad
ad
関連記事
-
-
ヤマムギ vol.9 (AWS)EC2からAWS CLIコマンドを実行してみようハンズオン 手順
このブログは2020/5/5に開催しました、「ヤマムギ vol.9 (AWS)E …
-
-
AWS Summit Tokyo 2017 Day3 開場~基調講演~Dev Day Night
AWS Summit Tokyo 2017 参加2日目のDay3です。 基調講演 …
-
-
[事前準備] JAWS-UG 関西IoT専門支部「マクニカkibo + AWS IoTハンズオン」
来る12/19(土)の JAWS-UG 関西IoT専門支部第一回勉強会「マクニカ …
-
-
PyCharmにAWS Tool kitをインストールしてサンプルのLambda関数をデプロイして実行しました
この記事はJetBrainsIDE Advent Calendar 2018に参 …
-
-
AD Connectorを作成してシームレスにドメイン参加する
VPN接続先のADで管理されているドメインにEC2 Windowsインスタンスか …
-
-
Amazon Quantum Ledger Database(QLDB)でサンプル台帳の作成と検証
Quantum Ledger Database(QLDB)を触ったことなかったの …
-
-
AWS EC2 Amazon Linuxにmauticをインストールする(Sendgrid, Nginx, MySQL on RDS)
mauticをAmazon LinuxとNginx,MySQL on RDSにイ …
-
-
Amazon CloudSearchにAWS Lambda(Python)からデータをアップロードする
このブログはゆるっとアドベントカレンダー Advent Calendar 201 …
-
-
Amazon CloudSearchからAmazon Elasticsearch Serviceへ変えました
全文検索をする必要がありまして、本当はCloudSearchを使い続けたいのです …
-
-
DynamoDB IAMポリシーで特定属性だけを許可する
検証記録です。 対象テーブル 書籍のサンプルで作ったこちらです。 所属バンドの楽 …