Spring Boot 應用監控常見方案梳理

松哥原創的 Spring Boot 視頻教程已經殺青,感興趣的小夥伴戳這裏-->Spring Boot+Vue+微人事視頻教程


應用監控是我們在生產環境下一個非常重要的東西,運維人員不可能 24 小時盯着應用,應用掛了及時解決,這不現實。我們需要能夠實時掌握應用的運行數據,以便提早發現問題,同時在應用掛掉的時候還能夠自動報警,這樣才能解放開發人員。

Spring Boot 中也提供了生產級的應用監控方案,對於單體應用、微服務應用都有相應的解決方案,今天松哥就想來和大家捋一捋 Spring Boot 中的應用監控方案都有哪些。

首先我們來捋一下應用監控都需要哪些東西?其實就兩點:

  1. 信息採集器
  2. 數據可視化 UI

信息採集器會收集應用的健康、審計、指標、HTTP 請求等信息,並將之暴露出來,數據可視化 UI 則會通過儀表盤、圖形等展示這些數據,並對數據進行分析、報警等處理。我們分別來看。

Spring Boot Actuator

在 Spring Boot 項目中,我們使用的信息採集器主要就是 Spring Boot Actuator,這個模塊由 Spring Boot 官方提供,它包含了許多生產級別的功能,例如健康檢查、審計、指標收集、HTTP 請求追蹤等,Spring Boot Actuator 將這些信息收集起來後,通過 HTTP 和 JMX 兩種方式暴露給外部模塊。例如 Spring Boot Actuator 通過 /health 端點(endpoints)提供了應用的健康信息,開發者只需要訪問該端點就可以看到應用的健康信息,但是這些端點返回的數據是 JSON 格式的,不方便查看,也不方便分析,所以一般情況下,Spring Boot Actuator 都是和一些外部模塊一起使用。

Spring Boot Actuator 支持的端點主要有如下一些:

如果是 Web 應用,則再次基礎上還支持如下端點:

提到 Spring Boot Actuator,就還有一個東西需要和大家介紹,那就是 Micrometer,從 Spring Boot2.0 開始,Actuator 底層改爲了 Micrometer。

當我們在一個 Spring Boot 項目中引入 Actuator 依賴之後,我們會發現它裏邊包含了 Micrometer:

這個依賴又是幹什麼的呢?

Micrometer 爲 Java 平臺上的性能數據收集提供了一個通用的 API,應用程序只需要使用 Micrometer 的通用 API 來收集性能指標即可,而 Micrometer 則會負責完成與不同監控系統的適配工作,類似於一個 Adapter,有了這個 Adapter,切換監控系統就變得非常容易。同時 Micrometer 還支持推送數據到多個不同的監控系統。

而 Spring Boot Actuator 使用 Micrometer 與外部應用監視系統進行集成,這樣一來,開發者只需要稍微配置一下就可以使其和外部應用監視系統進行整合了。Micrometer 支持的監控系統有:

  • AppOptics
  • Atlas
  • Datadog
  • Dynatrace
  • Elastic
  • Ganglia
  • Graphite
  • Humio
  • Influx
  • JMX
  • KairosDB
  • New Relic
  • Prometheus
  • SignalFx
  • Simple (in-memory)
  • StatsD
  • Wavefront

信息採集器這塊,老實說松哥見到的大部分項目都是用的 Spring Boot Actuator,似乎沒有其他更好的選擇。如果小夥伴們有用到其他方案,也可以留言討論。

接下來我們來看看一些常用的應用監控可視化工具。

Spring Boot Admin

這個算是 Spring Boot 中最最正宗的應用監控可視化工具了,看名字就知道有多正宗,當我們創建一個 Spring Boot 項目時,選擇依賴時候就有這個選項:

如果是單體應用很多人可能會選擇 Spring Boot Admin 作爲監控數據可視化工具,不過它也支持微服務應用的(可以通過 Eureka、Consul 等註冊中心獲取應用信息),只不過在微服務中,我們可能會更多的選擇 Grafana+Prometheus 組合。

Spring Boot Admin 主要包含如下功能:

  • 顯示應用健康信息。
  • 顯示應用運行的詳細信息,例如 JVM 和內存指標、數據源指標、緩存指標等等。
  • 顯示應用的構建信息。
  • 查看 JVM 系統和環境屬性
  • 查看 Spring Boot 配置屬性
  • 支持 Spring Cloud 中的端點刷新功能 /refresh-endpoint
  • 方便的日誌級別管理功能
  • 可以與 JMX-beans 進行交互
  • 查看 Thread dump
  • 查看 http 請求
  • 查看計劃任務
  • 查看和刪除活動會話
  • 查看 Flyway/Liquibase 數據庫遷移
  • 下載 heapdump
  • 狀態更改通知
  • ...

可以看到,Spring Boot Admin 不僅僅是將 Actuator 接口中的數據進行可視化,還在此基礎上提供了分析、報警等功能。

Spring Boot Admin 的顯示界面如下:

Grafana+Prometheus

這個組合在微服務項目中比較常見,松哥之前錄製的 Spring Cloud 視頻裏邊也有講到(公號後臺回覆 vhr 有視頻詳細介紹)。

Prometheus 是一款開源的監控 + 時序數據庫 + 報警軟件,由SoundCloud 公司開發的,在 CNCF 基金會託管並已成功孵化,不過這個 Prometheus 的 UI 比較簡單,用戶體驗不怎麼好,現在都流行大屏監控頁面,上面展示各種炫酷的圖表。所以在實際應用中,Prometheus 一般都是結合 Grafana 一起來使用,Grafana 也是一個開源的跨平臺度量分析和可視化 + 告警工具,它支持多種數據源,包括 Prometheus,Grafana 的 UI 就比較炫酷,如下:

當然,使用這套組合也離不開 Spring Boot Actuator。

小結

前面跟小夥伴們分享了 Spring Boot 應用監控的主流方案,沒說具體用法,後面抽空松哥會和大家聊一聊具體用法。除了這些主流的方案之後,還有很多小衆的方案,松哥也見到有極少數項目團隊自研應用監控方案。不過對於大多數的項目而言,這些現成的成熟方案無疑是最佳選擇。

好啦,今天就先和小夥伴們聊這麼多,後面我們再來看具體用法~

精彩文章推薦:

Spring Boot 要怎麼學?要學哪些東西?要不要先學 SSM?松哥說說看法
274 頁 pdf 文檔,Spring Boot 教程也有離線版了


喜歡就點個"在看"唄^_^

本文分享自微信公衆號 - 江南一點雨(a_javaboy)。
如有侵權,請聯繫 [email protected] 刪除。
本文參與“OSC源創計劃”,歡迎正在閱讀的你也加入,一起分享。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章