2
2

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.

CloudWatchのダッシュボードをSlackに通知する

Posted at

CloudWatch のダッシュボードって超イケてるですけど、見に行くの面倒くさいですよね。
というわけでSlackに定期的に通知するようにしました。

(公式でもっとイケてる手順があるなら知りたい)

全体像

Githubにあげてるので詳しくはそこ参照ください
https://github.com/takyam-git/cloudwatch-dashboard-notify-slack

できること

こんな感じのをLambda経由でSlack通知できるようになります。

Slack | develop | タノム 2020-10-13 21-48-51.png

内容

Lambda5千年ぶりくらいに書いたから、最近のプラクティスに添えてない可能性がすごいでかいですが、ポイントは以下

  • CloudWatchの画面からsourceをコピペってくる
  • 画像をAWS SDK経由で取得する
  • 結合する
  • Slackになげる

CloudWatchの画面からsourceをコピペってくる

通知したいCloudWatchダッシュボードの「アクション」を押すと「ソースを表示/編集」ってのがあって、
そこに現在設定されてる内容がJSONで取得できますです。

このJSONの widgets[].properties をSDKに投げると画像を返してくれる感じです。

CloudWatch Management Console 2020-10-13 22-05-04.png

CloudWatch Management Console 2020-10-13 22-07-11.png

画像をAWS SDK経由で取得する

const AWS = require('aws-sdk')
const source = require('./source.json')
const cloudwatch = new AWS.CloudWatch()

// 同じディレクトリにある source.json をもとにWidgetを取得する(後述)
const promises = source.widgets.map(async props =>
  cloudwatch
   .getMetricWidgetImage({
      OutputFormat: 'png',
      MetricWidget: JSON.stringify({
        ...props.properties,
        start: '-P14D', // 2週間レンジで取得
        timezone: '+0900' // JSTに変更
      })
    })
    .promise()
)
const imageBuffers = (await Promise.all(promises)).map(result => result.MetricWidgetImage)

さっきコピペしたJSONを cloudwatch.getMetricWidgetImage() にぶん投げると、いい感じにとれます。
APIの詳しい情報は https://docs.aws.amazon.com/AmazonCloudWatch/latest/APIReference/API_GetMetricWidgetImage.html この辺参照してください。

ここまでがCloudWatch周り。

結合する / Slackになげる

  • 1ポストで全画像投げたかったので、 merge-img ってのを使って結合しました(なんでもいいと思います)
  • SlackSDK経由でfile.upload API叩いてSlack通知します

(詳しくはgithubの方みてください)

おわり

ローカルで実行できたら、適当にLambdaのセットアップして、EventBridge設定しておしまいです。
特に数叩かれるわけでもないので、タイムアウト1分、メモリ512MBみたいなリッチな感じで設定してます。

2
2
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
2
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?