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なども可視化していきます。
最後までお読みいただきましてありがとうございました!
「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル 改訂第2版」という本を書きました。

「AWS認定資格試験テキスト AWS認定クラウドプラクティショナー 改訂第3版」という本を書きました。

「ポケットスタディ AWS認定 デベロッパーアソシエイト [DVA-C02対応] 」という本を書きました。

「要点整理から攻略するAWS認定ソリューションアーキテクト-アソシエイト」という本を書きました。

「AWSではじめるLinux入門ガイド」という本を書きました。


開発ベンダー5年、ユーザ企業システム部門通算9年、ITインストラクター5年目でプロトタイプビルダーもやりだしたSoftware Engineerです。
質問はコメントかSNSなどからお気軽にどうぞ。
出来る限りなるべく答えます。
このブログの内容/発言の一切は個人の見解であり、所属する組織とは関係ありません。
このブログは経験したことなどの共有を目的としており、手順や結果などを保証するものではありません。
ご参考にされる際は、読者様自身のご判断にてご対応をお願いいたします。
また、勉強会やイベントのレポートは自分が気になったことをメモしたり、聞いて思ったことを書いていますので、登壇者の意見や発表内容ではありません。
ad
ad
関連記事
-
-
Amazon Connectのパスワードどころかユーザー名も忘れたのでEmergency accessした
長い間放置していたAmazon Connect環境にアクセスしようとしたところ、 …
-
-
AWS東京リージョンのAZ(apne1-az1)障害時の当ブログで発生していたことの記録
日本時間2/19 23:01頃より、東京リージョン、特定AZの1つでEC2インス …
-
-
AWS Savings Plansを検討しました
今、個人でAWSアカウントを7つ使っています。 Savings Plansが使え …
-
-
AWS Toolkit for Eclipseで「Error Message: Unable to find a region via the region provider chain. Must provide an explicit region in the builder or setup environment to supply a region.」
AWS Toolkit for Eclipseをセットアップ(2021年版)の環 …
-
-
Amazon BedrockがGAしたので触りました(boto3からも)
Amazon Bedrock Is Now Generally Availabl …
-
-
ALBの重み付けルーティングでカナリアリリースをしてみました
当ブログのAMIの更新と、ALBターゲットグループのヘルスチェックを変更したかっ …
-
-
Amazon FSx for Lustreのユーザーガイド入門演習
ファイルシステムの作成 FSx for Lustreを選択しました。 容量やスル …
-
-
T2.microからT3.nanoに変更(メモリエラーも対応)
このブログのEC2インスタンスをT2.micro 1インスタンスからT3.nan …
-
-
「機械学習モデルをトレーニングする」チュートリアル
Amazon SageMaker Clarifyのデモを記録しておきたいので「機 …
-
-
Cloud9初回アクセス時にCodeCommitのリポジトリを自動でクローンする
CloudFormationからCloud9環境を作成する際に、Reposito …