使用 HertzBeat 5分鐘搞定 SpringBoot2 監控告警

語言: CN / TW / HK

使用開源實時監控工具 HertzBeat 對 SpringBoot2 應用的監控告警實踐,5分鐘搞定!

HertzBeat 介紹

> HertzBeat 是一款開源,易用友好的實時監控工具,無需Agent,擁有強大自定義監控能力。

  • 監控-告警-通知為一體,支持對應用服務,數據庫,操作系統,中間件,雲原生,網絡等監控,閾值告警,告警通知(郵件微信釘釘飛書短信 Slack Discord Telegram)。
  • 其將Http,Jmx,Ssh,Snmp,Jdbc等協議規範可配置化,只需配置YML就能使用這些協議去自定義採集任何您想要採集的指標。您相信只需配置YML就能立刻適配一個K8s或Docker等新的監控類型嗎?
  • HertzBeat 的強大自定義,多類型支持,易擴展,低耦合,希望能幫助開發者和中小團隊快速搭建自有監控系統。

Github: https://github.com/dromara/hertzbeat

在 HertzBeat 5分鐘搞定對 SpringBoot2 應用的監控

操作前提,您已擁有 SpringBoot2 應用環境和 HertzBeat 環境。

一. 在 SpringBoot2 應用端暴露出actuator指標接口,它將提供 metrics 接口數據。

  1. 開啟 SpringBoot Actuator Endpoint 暴露出metrics health env指標接口
management:
  endpoints:
    web:
      exposure:
        include:
          - 'metrics'
          - 'health'
          - 'env'
    enabled-by-default: on
  1. 重啟後測試訪問指標接口 ip:port/actuator 是否有響應json數據如下:
{
  "_links": {
    "self": {
      "href": "http://localhost:1157/actuator",
      "templated": false
    },
    "health-path": {
      "href": "http://localhost:1157/actuator/health/{*path}",
      "templated": true
    },
    "health": {
      "href": "http://localhost:1157/actuator/health",
      "templated": false
    },
    "env": {
      "href": "http://localhost:1157/actuator/env",
      "templated": false
    },
    "env-toMatch": {
      "href": "http://localhost:1157/actuator/env/{toMatch}",
      "templated": true
    },
    "metrics-requiredMetricName": {
      "href": "http://localhost:1157/actuator/metrics/{requiredMetricName}",
      "templated": true
    },
    "metrics": {
      "href": "http://localhost:1157/actuator/metrics",
      "templated": false
    }
  }
}

在開源監控系統 HertzBeat 監控頁面添加對 SpringBoot2 應用監控

  1. 點擊新增 SpringBoot2 監控

路徑:菜單 -> 應用服務監控 -> SpringBoot2 -> 新增SpringBoot2監控

monitor-springboot2-1.png

  1. 配置新增監控 SpringBoot2 所需參數

在監控頁面填寫 SpringBoot2應用 對端IP服務端口(默認8080),賬户密碼等,最後點擊確定添加即可。
其他參數如採集間隔超時時間等可以參考幫助文檔 https://hertzbeat.com/docs/help/

monitor-springboot2-2.png

  1. 完成✅,現在我們已經添加好對 SpringBoot2應用 的監控了,查看監控列表即可看到我們的添加項。

monitor-springboot2-3.png

  1. 點擊監控列表項的操作->監控詳情圖標 即可瀏覽 SpringBoot2應用 的實時監控指標數據。

monitor-springboot2-4.png

  1. 點擊監控歷史詳情TAB 即可瀏覽 SpringBoot2應用 的歷史監控指標數據圖表📈。

monitor-springboot2-5.png

DONE!完成啦!不需要我們去部署agent或者各種繁瑣操作,是不是很簡單

  • 只需一步在 HertzBeat 監控頁面配置IP端口添加 SpringBoot2應用 監控即可

> 通過上面我們就完成了對 SpringBoot2應用 的監控,我們可以在 HertzBeat 隨時查看SpringBoot2應用的各種指標狀態和可用性。
當然不可能人工一直實時查看指標,監控往往伴隨着告警閾值,當 SpringBoot2應用 的性能指標超出我們的閾值或SpringBoot2應用本身異常時,能及時的通知到我們對應的負責人,負責人收到通知處理,這樣才是一個完整的監控告警流程。

接下來我們就來一步一步演示如何配置 HertzBeat 系統裏的閾值告警通知,當 SpringBoot2應用 的指標異常時,及時通知給我們

三. 在 HertzBeat 系統添加 SpringBoot2應用 指標閾值告警

  1. 對某個重要指標配置告警閾值

路徑:菜單 -> 閾值規則 -> 新增閾值

  • 選擇配置的指標對象,SpringBoot2應用 監控主要是 堆棧內存 線程等相關指標,我們舉例對 狀態線程數 threads -> threads 這個指標進行閾值設置, 當runnable狀態的線程數量大於300時發出告警。
  • 這裏我們就配置當此指標size,stateequals(state,"runnable"") && size>300 時發出告警,告警級別為警告告警,三次即觸發,具體如下圖。

monitor-springboot2-6.png

monitor-springboot2-7.png

  1. 新增消息通知接收人

> 配置接收人,讓告警消息知道要發給誰,用什麼方式發。

路徑:菜單 -> 告警通知 -> 告警接收人 -> 新增接收人

消息通知方式支持 郵件,釘釘,企業微信,飛書,WebHook,短信等,我們這裏以常用的釘釘為例。

【告警通知】->【新增接收人】 ->【選擇釘釘機器人通知方式】->【設置釘釘機器人ACCESS_TOKEN】-> 【確定】

alert-notice-1.png

  1. 配置關聯的告警通知策略⚠️ 【新增通知策略】-> 【將剛設置的接收人關聯】-> 【確定】

> 配置告警通知策略,讓告警消息與接收人綁定,這樣就能決定哪些告警發給哪個人。

alert-notice-2.png

完畢,現在坐等告警消息過來啦。叮叮叮叮

[HertzBeat告警通知]
告警目標對象 : springboot2.threads.size
所屬監控ID : 483783444839322
所屬監控名稱 : SPRINGBOOT2_localhost
告警級別 : 警告告警
告警觸發時間 : 2023-03-22 21:13:44
內容詳情 : The springboot2 service's runnable state threads num is over 300, now is 444.

小結

:::tip 這篇實踐文章帶我們體驗瞭如何使用開源實時監控工具 HertzBeat 來監控 SpringBoot2應用 指標數據,可以發現集 監控-告警-通知 的 HertzBeat 在操作與使用方面更加的便捷,只需頁面上簡單點一點就能把 SpringBoot2應用 納入監控並告警通知,再也不需要部署多個組件編寫配置文件那些繁瑣操作了。
:::

> 只需要一條docker命令即可安裝體驗heartbeat:

docker run -d -p 1157:1157 --name hertzbeat tancloud/hertzbeat

更強大

> 通過上面的簡單步驟我們實現了對SpringBoot2的監控,但裏面的內置指標固定不滿足需要,是否能自定義監控更多SpringBoot2的指標呢?答案當然是可以的,通過在頁面上的監控定義->SpringBoot2隨時通過編輯如下的YML配置文件自定義添加修改想要監控的性能指標。

monitor-springboot2-8.png

What is HertzBeat?

> HertzBeat赫茲跳動 是一個擁有強大自定義監控能力,無需Agent的實時監控告警工具。應用服務,數據庫,操作系統,中間件,雲原生,網絡等監控,閾值告警,告警通知(郵件微信釘釘飛書短信 Discord Slack Telegram)。

> 我們將Http,Jmx,Ssh,Snmp,Jdbc等協議規範可配置化,只需配置YML就能使用這些協議去自定義採集任何您想要採集的指標。
> 您相信只需配置YML就能立刻適配一個K8s或Docker等新的監控類型嗎?

> HertzBeat的強大自定義,多類型支持,易擴展,低耦合,希望能幫助開發者和中小團隊快速搭建自有監控系統。

Github: https://github.com/dromara/hertzbeat
Gitee: https://gitee.com/dromara/hertzbeat

⛄ Supported

  • 網站監控, 端口可用性, Http Api, Ping連通性, Jvm, SiteMap全站, Ssl證書, SpringBoot, FTP服務器
  • Mysql, PostgreSQL, MariaDB, Redis, ElasticSearch, SqlServer, Oracle, MongoDB, 達夢, OpenGauss, ClickHouse, IoTDB
  • Linux, Ubuntu, CentOS, Windows
  • Tomcat, Nacos, Zookeeper, RabbitMQ, Flink, Kafka, ShenYu, DynamicTp, Jetty, ActiveMQ
  • Kubernetes, Docker
  • CiscoSwitch, HpeSwitch, HuaweiSwitch, TpLinkSwitch
  • 和更多的自定義監控。
  • 通知支持 Discord Slack Telegram 郵件 釘釘 微信 飛書 短信 Webhook