起因:老闆想要用手機看 Grafana 的某個 Panel,叫我想個辦法 (・ε・)
本篇文章將會使用 hutbot-grafana 整合 Slack 和 Grafana,使用者可以透過 Chatbot 將 Grafana 的數據直接存成圖片,上傳 Slack。
如下圖展示:
data:image/s3,"s3://crabby-images/cb7dc/cb7dc0aa793db8b18f2673ec969056455ff72c8d" alt="You will get this after this tutorial"
本篇文章不會提到:
- Grafana Setup
- NodeJS Setup
使用到的工具:
- yo - 快速建立專案的工具
- hutbot-grafana - 使用 Slack 查詢 Grafana Dashboard
- Hubot - ChatOps Framework
- Slack - 2019 最好用的辦公通訊軟體
Project Setup
mkdir grafana-bot |
Add hubot-grafana
in external-scripts.json
[ |
取得 HUBOT_GRAFANA_API_KEY
這邊只需要 Viewer 的權限即可
data:image/s3,"s3://crabby-images/b2141/b2141e2a625826458ea2fa85c267bf9853810837" alt="Get Grafana API Key"
取得 HUBOT_SLACK_TOKEN
到 https://swaglive.slack.com/apps/manage 新增 Hubot
data:image/s3,"s3://crabby-images/2ed7c/2ed7ca957386d92bebd240b6ebd3a90270ac6d44" alt="Add Hubot App into Workspace"
在你想要使用 Chatbot 的頻道加入這個 Chatbot.
ex: /invite @grafana-bot
,請改成自己的 bot 名稱。
data:image/s3,"s3://crabby-images/fc608/fc608c08caec52a28ff65768ccb2602fae2c3b55" alt="Invite grafana-bot"
開始使用 Bot
傳入環境變數
export HUBOT_GRAFANA_HOST=http://...... |
啟動 Bot CLI
可以在 terminal 與 Bot 互動
./bin/hubot |
data:image/s3,"s3://crabby-images/d1aaf/d1aaf5f966e20f31c8455cc9b70fa8a00c0b62bb" alt="Locally start bot"
啟動 Bot Slack 模式
才能在 Slack 頻道與 Bot 互動
./bin/hubot -a slack |
data:image/s3,"s3://crabby-images/01500/01500c7b7ea741b8d456edfea6d3bd424833a1eb" alt="Locally start bot"
hubot-grafana commands
graf list
: 列出所有 dashboardgraf db <dashboard>
: 取得 dashboard 的所有 panelgraf db <dashboard>:<panel>
: 查詢 dashboard 符合名稱的所有 panel,不分大小寫 graf db <dashboard> now-30m now
: 查詢 dashboard 兩個時間區間的資料