初識Spring boot監(jiān)控
最近對devOps這個話題有點興趣,所以研究了一下monitor相關的開源項目,翻到medium上的一篇文章,而且實際項目中也曾看到devOps組的同事搭過類似的監(jiān)控,就想過把癮,了解一下監(jiān)控可視化。
被監(jiān)控服務配置
本地正好有spring-boot的項目,并且也依賴了jolokia(主要就是為了把JMX的mbean通過HTTP暴露出去)
項目配置也少不了
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端配置沒問題了,下面我們怎么搭建Telegraf + InfluxDB + Grafana呢,這個三個組件是這么配合的,Telegraf實際就是收集信息的,比如每隔10s訪問一次上面那個URL得到metrics,收集到的數(shù)據(jù)存到InfluxDB,然后Grafana做數(shù)據(jù)可視化。
但是如果純手動安裝實在太麻煩,求助萬能的github,找到一個非常棒的項目(https://github.com/samuelebistoletti/docker-statsd-influxdb-grafana), 直接fork然后修改一些配置就可以為自己的項目服務了。如果你不了解相關配置可以先直接run起來,然后通過ssh進去一探究竟。
ssh root@localhost -p 22022
配置方面,主要是要修改Telegraf的,因為它是對接不同項目的,你需要收集什么樣的信息,比如cpu,disk,net等等都要在Telegraf里配。簡單起見,我只設置了三個輸入。
# /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"
其實就是spring-boot標準的metrics以及tomcat的Threads。
完成之后重啟服務/etc/init.d/telegraf restart
查看監(jiān)控數(shù)據(jù)
我們訪問InfluxDB看看有數(shù)據(jù)了沒有http://localhost:3004/,切換數(shù)據(jù)庫到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收集一次,太頻繁了對server也是壓力。
上面基本涵蓋了cpu,內(nèi)存和存儲的一些metrics。
其實也可以配置網(wǎng)絡相關的,感興趣的可以看官方的telegraf.conf,里面有配置[[inputs.net]]的例子。
數(shù)據(jù)可視化
數(shù)據(jù)有了,下一步就是可視化。
按照Github上面說的進入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后,新建一個Dashboard,然后快速的ADD幾個Graph來。
為了演示,我添加了三個,分別使用下面三組查詢語句來渲染出三張圖表
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)
小結
以上所述是小編給大家介紹的Spring boot監(jiān)控,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- 詳解使用spring boot admin監(jiān)控spring cloud應用程序
- spring-boot使用Admin監(jiān)控應用的方法
- springboot 使用Spring Boot Actuator監(jiān)控應用小結
- Spring Boot使用Druid進行維度的統(tǒng)計和監(jiān)控
- 詳解Spring boot Admin 使用eureka監(jiān)控服務
- 詳解Spring Boot Admin監(jiān)控服務上下線郵件通知
- 詳解關于springboot-actuator監(jiān)控的401無權限訪問
- 詳解spring-boot actuator(監(jiān)控)配置和使用
- SpringBoot 監(jiān)控管理模塊actuator沒有權限的問題解決方法
- Spring Boot應用監(jiān)控的實戰(zhàn)教程
相關文章
Spring Boot中使用activiti的方法教程(一)
最近一直研究springboot,下面這篇文章主要給大家介紹了關于Spring Boot中使用activiti的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧2018-08-08springboot如何獲取相對路徑文件夾下靜態(tài)資源的方法
這篇文章主要介紹了springboot如何獲取相對路徑文件夾下靜態(tài)資源的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05IDEA2023 Maven3.9.1+Tomcat10.1.8配置并搭建Servlet5.0的框架實現(xiàn)
本文主要介紹了IDEA2023 Maven3.9.1+Tomcat10.1.8配置并搭建Servlet5.0的框架實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07java web開發(fā)之購物車功能實現(xiàn)示例代碼
這篇文章主要介紹了java web開發(fā)之購物車功能實現(xiàn)示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10