初識(shí)Spring boot監(jiān)控
最近對(duì)devOps這個(gè)話題有點(diǎn)興趣,所以研究了一下monitor相關(guān)的開源項(xiàng)目,翻到medium上的一篇文章,而且實(shí)際項(xiàng)目中也曾看到devOps組的同事搭過類似的監(jiān)控,就想過把癮,了解一下監(jiān)控可視化。
被監(jiān)控服務(wù)配置
本地正好有spring-boot的項(xiàng)目,并且也依賴了jolokia(主要就是為了把JMX的mbean通過HTTP暴露出去)
項(xiàng)目配置也少不了
endpoints: enabled: true jmx: enabled: true jolokia: enabled: true management: security: enabled: false
訪問一下URL看看是不是ok
http://localhost:8080/jolokia/read/org.springframework.boot:name=metricsEndpoint,type=Endpoint/Data
搭建監(jiān)控系統(tǒng)
如果能看到數(shù)據(jù),說明server端配置沒問題了,下面我們?cè)趺创罱═elegraf + InfluxDB + Grafana呢,這個(gè)三個(gè)組件是這么配合的,Telegraf實(shí)際就是收集信息的,比如每隔10s訪問一次上面那個(gè)URL得到metrics,收集到的數(shù)據(jù)存到InfluxDB,然后Grafana做數(shù)據(jù)可視化。
但是如果純手動(dòng)安裝實(shí)在太麻煩,求助萬能的github,找到一個(gè)非常棒的項(xiàng)目(https://github.com/samuelebistoletti/docker-statsd-influxdb-grafana), 直接fork然后修改一些配置就可以為自己的項(xiàng)目服務(wù)了。如果你不了解相關(guān)配置可以先直接run起來,然后通過ssh進(jìn)去一探究竟。
ssh root@localhost -p 22022
配置方面,主要是要修改Telegraf的,因?yàn)樗菍?duì)接不同項(xiàng)目的,你需要收集什么樣的信息,比如cpu,disk,net等等都要在Telegraf里配。簡(jiǎn)單起見,我只設(shè)置了三個(gè)輸入。
# /etc/telegraf/telegraf.conf
[[inputs.jolokia]]
context = "/jolokia"
[[inputs.jolokia.servers]]
name = "springbootapp"
host = "{app ip address}"
port = "8080"
[[inputs.jolokia.metrics]]
name = "metrics"
mbean = "org.springframework.boot:name=metricsEndpoint,type=Endpoint"
attribute = "Data"
[[inputs.jolokia.metrics]]
name = "tomcat_max_threads"
mbean = "Tomcat:name=\"http-nio-8080\",type=ThreadPool"
attribute = "maxThreads"
[[inputs.jolokia.metrics]]
name = "tomcat_current_threads_busy"
mbean = "Tomcat:name=\"http-nio-8080\",type=ThreadPool"
attribute = "currentThreadsBusy"
其實(shí)就是spring-boot標(biāo)準(zhǔn)的metrics以及tomcat的Threads。
完成之后重啟服務(wù)/etc/init.d/telegraf restart
查看監(jiān)控?cái)?shù)據(jù)
我們?cè)L問InfluxDB看看有數(shù)據(jù)了沒有http://localhost:3004/,切換數(shù)據(jù)庫(kù)到Telegraf。輸入以下命令試試吧
SHOW MEASUREMENTS SELECT * FROM jolokia SELECT * FROM cpu SELECT * FROM mem SELECT * FROM diskio
比如輸入SELECT * FROM jolokia就能看到spring-boot暴露了哪些數(shù)據(jù),從time列也可以看出Telegraf是每隔10s收集一次,太頻繁了對(duì)server也是壓力。

上面基本涵蓋了cpu,內(nèi)存和存儲(chǔ)的一些metrics。
其實(shí)也可以配置網(wǎng)絡(luò)相關(guān)的,感興趣的可以看官方的telegraf.conf,里面有配置[[inputs.net]]的例子。
數(shù)據(jù)可視化
數(shù)據(jù)有了,下一步就是可視化。
按照Github上面說的進(jìn)入http://localhost:3003/,
Using the wizard click on Add data source Choose a name for the source and flag it as Default Choose InfluxDB as type Choose direct as access Fill remaining fields as follows and click on Add without altering other fields Url: http://localhost:8086 Database: telegraf User: telegraf Password: telegraf
添加好InfluxDB后,新建一個(gè)Dashboard,然后快速的ADD幾個(gè)Graph來。
為了演示,我添加了三個(gè),分別使用下面三組查詢語句來渲染出三張圖表
SELECT MEAN(usage_system) + MEAN(usage_user) AS cpu_total FROM cpu WHERE $timeFilter GROUP BY time($interval)
SELECT mean("total") as "total" FROM "mem" WHERE $timeFilter GROUP BY time($interval) fill(null)
SELECT mean("used") as "used" FROM "mem" WHERE $timeFilter GROUP BY time($interval) fill(null)
SELECT mean("metrics_heap.used") as "heap_usage" FROM "jolokia" WHERE $timeFilter GROUP BY time($interval) fill(null)
第一張是CPU占用率;第二張是內(nèi)存占用情況,綠線是Total,黃線是Used;第三張是jolokia提供的jvm heap的使用,可以到看到GC的情況。

剛才還配置了Tomcat的收集,想看Tomcat的Thread情況也是妥妥的。
SELECT mean("tomcat_max_threads") FROM "jolokia" WHERE $timeFilter GROUP BY time($interval) fill(null)
SELECT mean("tomcat_current_threads_busy") FROM "jolokia" WHERE $timeFilter GROUP BY time($interval) fill(null)

小結(jié)
以上所述是小編給大家介紹的Spring boot監(jiān)控,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 詳解使用spring boot admin監(jiān)控spring cloud應(yīng)用程序
- spring-boot使用Admin監(jiān)控應(yīng)用的方法
- springboot 使用Spring Boot Actuator監(jiān)控應(yīng)用小結(jié)
- Spring Boot使用Druid進(jìn)行維度的統(tǒng)計(jì)和監(jiān)控
- 詳解Spring boot Admin 使用eureka監(jiān)控服務(wù)
- 詳解Spring Boot Admin監(jiān)控服務(wù)上下線郵件通知
- 詳解關(guān)于springboot-actuator監(jiān)控的401無權(quán)限訪問
- 詳解spring-boot actuator(監(jiān)控)配置和使用
- SpringBoot 監(jiān)控管理模塊actuator沒有權(quán)限的問題解決方法
- Spring Boot應(yīng)用監(jiān)控的實(shí)戰(zhàn)教程
相關(guān)文章
IDEA 單元測(cè)試創(chuàng)建方法詳解(2020.03版本親測(cè))
這篇文章主要介紹了IDEA 單元測(cè)試創(chuàng)建方法詳解(2020.03版本親測(cè)),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10
SpringBatch結(jié)合SpringBoot簡(jiǎn)單使用實(shí)現(xiàn)工資發(fā)放批處理操作方式
這篇文章主要介紹了SpringBatch結(jié)合SpringBoot簡(jiǎn)單使用實(shí)現(xiàn)工資發(fā)放批處理操作方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Springboot+Thymeleaf+Jpa實(shí)現(xiàn)登錄功能(附源碼)
最近有學(xué)習(xí)到關(guān)于Springboot+Thymeleaf+Jpa的綜合運(yùn)用知識(shí),因此想寫一個(gè)簡(jiǎn)單的登錄界面來嘗試一下,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05
SpringBoot請(qǐng)求參數(shù)傳遞與接收說明小結(jié)
這篇文章主要介紹了SpringBoot請(qǐng)求參數(shù)傳遞與接收,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
spring監(jiān)視器actuator配置應(yīng)用
這篇文章主要介紹了spring監(jiān)視器actuator配置應(yīng)用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07
SpringBoot參數(shù)校驗(yàn)及原理全面解析
文章介紹了SpringBoot中使用@Validated和@Valid注解進(jìn)行參數(shù)校驗(yàn)的方法,包括基本用法和進(jìn)階用法,如自定義驗(yàn)證注解、多屬性聯(lián)合校驗(yàn)和嵌套校驗(yàn),并簡(jiǎn)要介紹了實(shí)現(xiàn)原理2024-11-11

