やること
Amazon ESにCloudTrailのログを流し、test_user1のログイン成功を検知したらアラートを飛ばします
これをOpenDistroのAlartingを使ってやる
事前準備
Amazon ESはv6.5でセットアップし、CloudTrailのログを流し込んでいます。
Slackを用意してWebhook URLを控えておく
- Amazon ES: v6.5
画面はKibanaで「eventType: AwsConsoleSignIn AND userIdentity.userName: test_user1 AND responseElements.ConsoleLogin: Success」でフィルタをして"test_user1"というIAMユーザーでログインに成功したデータを検索しています。
data:image/s3,"s3://crabby-images/5ebfc/5ebfca313ca702eb37cff9e3441594ac79afd64b" alt="スクリーンショット 0031-05-14 17.28.46.png"
OpenDistro Alarmの設定
Destination
Kibanaの左側メニューで"Alerting"をクリックし、[Add Destination]をクリックします。
data:image/s3,"s3://crabby-images/0c848/0c8483cb5c4554bb0747f2a5e3e5abfaf6ec0846" alt="スクリーンショット 0031-05-14 17.32.05.png"
今回は通知先をSlackとします。以下の情報いれて[Create]をクリック
- Name: test_trigger
- Type: Slack
- Webhook URL: 自身のSlackのやつ
カスタムWebhook含め送り先は選べます
data:image/s3,"s3://crabby-images/e5101/e51017f08c882e5ac1e20adaffc10e5754b20915" alt="スクリーンショット 0031-05-14 17.34.52.png"
これでDestinationは完成
Monitor
"Monitor"をクリックし[Create monitor]をクリック
data:image/s3,"s3://crabby-images/7d093/7d0934109a3edd9f9eb5215cfebd9a27f5bff9f7" alt="スクリーンショット 0031-05-14 17.37.12.png"
以下を入力
- Monitor name: test_monitor
- Every: 5
data:image/s3,"s3://crabby-images/920d1/920d1a7f0ea3aacdb892bb88ac2e795652271773" alt="スクリーンショット 0031-05-14 17.38.30.png"
以下を入力し、右下の[Create]をクリックする
- How do you want to define the monitor?: Define using extraction query
- Index: cwl-2019.05.14
- Define extraction query: 以下のクエリを入力
{
"size": 0,
"query": {
"bool": {
"must": [
{
"match": {
"eventType": {
"query": "AwsConsoleSignIn",
"operator": "AND",
"prefix_length": 0,
"max_expansions": 50,
"fuzzy_transpositions": true,
"lenient": false,
"zero_terms_query": "NONE",
"auto_generate_synonyms_phrase_query": true,
"boost": 1
}
}
},
{
"match": {
"userIdentity.userName": {
"query": "test_user1",
"operator": "AND",
"prefix_length": 0,
"max_expansions": 50,
"fuzzy_transpositions": true,
"lenient": false,
"zero_terms_query": "NONE",
"auto_generate_synonyms_phrase_query": true,
"boost": 1
}
}
},
{
"match": {
"responseElements.ConsoleLogin": {
"query": "Success",
"operator": "AND",
"prefix_length": 0,
"max_expansions": 50,
"fuzzy_transpositions": true,
"lenient": false,
"zero_terms_query": "NONE",
"auto_generate_synonyms_phrase_query": true,
"boost": 1
}
}
}
],
"filter": [
{
"range": {
"@timestamp": {
"from": "now-10m",
"to": null,
"include_lower": true,
"include_upper": true,
"boost": 1
}
}
}
],
"adjust_pure_negative": true,
"boost": 1
}
},
"aggregations": {}
}
data:image/s3,"s3://crabby-images/bb121/bb1213cdbf7365c0d7cd3acb11864528591bb093" alt="スクリーンショット 0031-05-14 17.40.52.png"
Trigger
Create Trigger の画面になるので、以下の値を入力する
- Trigger name: test_trigger1
data:image/s3,"s3://crabby-images/f5a68/f5a68a2931b8096c8b14738c119e970c94d4ecc5" alt="スクリーンショット 0031-05-14 17.45.20.png"
Trigger conditionがhit件数>0となっている。右下の[Run]をクリックしfalseであることを確認(今は10分以内のログインがなく0件なのでfalse)
data:image/s3,"s3://crabby-images/8f2ad/8f2ad61a299d68cd183859a5152251c4498ae0d7" alt="スクリーンショット 0031-05-14 17.47.12.png"
Action
以下を入力し、[Add action]をクリックする
- Action name: test_action1
- Destination name: test_general - (Slack)
- Message subject: login success! test_user1
※入力が終わったら、右下の"Send test message"でWebhookの確認をしてもよい
data:image/s3,"s3://crabby-images/b8468/b8468ef067df5e1473d31c2cb3ba8cb08ff37a29" alt="スクリーンショット 0031-05-14 17.52.28.png"
右下の"Send test message"でWebhookの確認をした結果のSlack画面
data:image/s3,"s3://crabby-images/77438/77438862a4a01a15ac6ba3fb49f208ba6a54f1a1" alt="スクリーンショット 0031-05-14 18.09.25.png"
アクションができたら右下の[Create]をクリックする
data:image/s3,"s3://crabby-images/9b008/9b00847220b36221300f0695c97839b5de8a801d" alt="スクリーンショット 0031-05-14 17.54.36.png"
作成した"test_monitor1"
data:image/s3,"s3://crabby-images/132ac/132acbced3601e35f685bdd6eea5000eebcda24e" alt="スクリーンショット 0031-05-14 17.56.11.png"
テスト
test_user1でAWSに2回ほどログイン/ログアウトを行いしばらく待つ
test_monitor1の画面でアラートが発生したことがわかる
data:image/s3,"s3://crabby-images/1d2bc/1d2bc7d567cf243e9953158448348fb627af8ec8" alt="スクリーンショット 0031-05-14 18.13.01.png"
Slackにも飛んできた
data:image/s3,"s3://crabby-images/aabdd/aabdd13399f5e4c1d386cbe80a7da46c3e9458f6" alt="スクリーンショット 0031-05-14 18.11.01.png"
KibanaのDiscoverでも確認できる
data:image/s3,"s3://crabby-images/b1200/b12005f41abe774dcd0bebde96d384ec8693cf35" alt="スクリーンショット 0031-05-14 18.11.31.png"
今回だとDefine extraction queryを直近10分でクエリしているので、10分経つとAlertのStateはCompletedとなる
Dashboardの画面
data:image/s3,"s3://crabby-images/5f7d3/5f7d340a94a13dee0e04493219c42f2bd64b4ef2" alt="スクリーンショット 0031-05-14 18.20.26.png"
Monitor側の画面
data:image/s3,"s3://crabby-images/f807e/f807edc7a844ec27a9db10f47324c7890fab1600" alt="スクリーンショット 0031-05-14 18.22.31.png"