SpringBoot中如何對(duì)actuator進(jìn)行關(guān)閉
SpringBoot對(duì)actuator進(jìn)行關(guān)閉
management: endpoint: health: show-details: ALWAYS endpoints: enabled-by-default: false #關(guān)閉監(jiān)控 web: exposure: include: '*'
SpringBoot actuator知識(shí)梳理
Spring Boot的Actuator。它提供了很多生產(chǎn)級(jí)的特性,比如監(jiān)控和度量Spring Boot應(yīng)用程序。Actuator的這些特性可以通過眾多REST端點(diǎn)、遠(yuǎn)程shell和JMX獲得。
【使用環(huán)境】
【1】SpringBoot版本2.5.0、JDK11
【2】服務(wù)端口 9999
添加依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>
啟動(dòng)項(xiàng)目,訪問/actuator端點(diǎn),SpringBoot2.X版本默認(rèn)只開啟了如下端點(diǎn)
可以通過下面的方式開啟其他的端點(diǎn),如果需要關(guān)閉某些端點(diǎn)可以在exclude中設(shè)置。
management: endpoints: web: exposure: include: "*" exclude: ""
重新啟動(dòng)項(xiàng)目,可以看到現(xiàn)在展示的端點(diǎn)增加了很多
官方文檔:
https://docs.spring.io/spring-boot/docs/current/reference/html/actuator.html#actuator.endpoints
Actuator端點(diǎn)整理
/autoconfig和/conditions 獲取自動(dòng)配置條件
提供了一份自動(dòng)配置報(bào)告,記錄哪些自動(dòng)配置條件通過了,哪些沒通過。新版本已經(jīng)調(diào)整為conditions。Spring Boot自動(dòng)配置構(gòu)建于Spring的條件化配置之上。它提供了眾多帶有@Conditional注解的配置類,根據(jù)條件決定是否要自動(dòng)配置這些Bean。/autoconfig端點(diǎn)提供了一個(gè)報(bào)告,列出了計(jì)算過的所有條件,根據(jù)條件是否通過進(jìn)行分組。
端點(diǎn):http://localhost:9999/actuator/conditions
【舉例】
上面是失敗的一個(gè)條件示例,如圖所示是JdbcTemplate,這個(gè)類可以幫助我們操作數(shù)據(jù)庫(kù)。因?yàn)槲匆胂嚓P(guān)的依賴類所以正如它的提示信息所說:
“message”: “@ConditionalOnClass did not find required class ‘org.springframework.jdbc.core.JdbcTemplate’”
檢查Classpath沒有要求的JdbcTemplate條件不成立,則不會(huì)進(jìn)行自動(dòng)配置
/beans 獲得Bean裝配報(bào)告
要了解應(yīng)用程序中Spring上下文的情況,最重要的端點(diǎn)就是/beans。它會(huì)返回一個(gè)JSON文檔,描述上下文里每個(gè)Bean的情況,包括其Java類型以及注入的其他Bean。
請(qǐng)求端點(diǎn):/actuator/beans
/env端點(diǎn)查看配置屬性
/env端點(diǎn)會(huì)生成應(yīng)用程序可用的所有環(huán)境屬性的列表,無論這些屬性是否用到。這其中包括環(huán)境變量、JVM屬性、命令行參數(shù),以及applicaition.properties或application.yml文件提供的屬性。
端點(diǎn):/actuator/env
/env提供了一些安全策略保護(hù)配置的隱私性。為了避免此類信息暴露到/env里,所有名為password、secret、key(或者名字中最后一段是這些)的屬性在/env里都會(huì)加上“*”,參考如下:
/mapping請(qǐng)求URL映射
/mapping端點(diǎn)展示了所有@RequestMapping 請(qǐng)求路徑
請(qǐng)求端點(diǎn):/actuator/mappings
【測(cè)試接口】
@GetMapping(value = "/hello", produces = "application/json;charset=utf-8") public String hello(@RequestParam("name") String name) { return "hello world"; }
每個(gè)映射的值都有兩個(gè)屬性:bean和method。bean屬性標(biāo)識(shí)了Spring
Bean的名字,映射源自這個(gè)Bean。method屬性是映射對(duì)應(yīng)方法的全限定方法簽名。
/metrics運(yùn)行時(shí)指標(biāo)監(jiān)控
/metrics為我們提供了對(duì)運(yùn)行時(shí)度量情況的一個(gè)監(jiān)控,能夠在運(yùn)行時(shí)快速檢查應(yīng)用程序。
端點(diǎn):/actuator/metrics
主要的監(jiān)控事項(xiàng)如下:
/metrics端點(diǎn)會(huì)返回所有的可用度量值,但你也可能只對(duì)某個(gè)值感興趣。要獲取單個(gè)值,請(qǐng)求時(shí)可以在URL后加上對(duì)應(yīng)的鍵名。
如上圖所示,查詢jvm最大內(nèi)存,結(jié)果值大約為6G。
/httptrace 追蹤Web請(qǐng)求
/httptrace端點(diǎn)能報(bào)告所有Web請(qǐng)求的詳細(xì)信息,包括請(qǐng)求方法、路徑、時(shí)間戳以及請(qǐng)求和響應(yīng)的頭信息。
【請(qǐng)求端點(diǎn)】/actuator/httptrace
默認(rèn)情況下httptrace沒有啟用,它要求一個(gè)HttpTraceRepository 的對(duì)象Bean.
在系統(tǒng)中創(chuàng)建如下配置,提供一個(gè)HttpTraceRepository 類型的Bean,這里選擇的是InMemoryHttpTraceRepository內(nèi)存存儲(chǔ)的方式。該方式默認(rèn)提供最新的100條請(qǐng)求記錄。
import org.springframework.boot.actuate.trace.http.HttpTraceRepository; import org.springframework.boot.actuate.trace.http.InMemoryHttpTraceRepository; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class HttpTraceActuatorConfiguration { @Bean public HttpTraceRepository httpTraceRepository() { return new InMemoryHttpTraceRepository(); } }
/dump 導(dǎo)出線程快照
/dump端點(diǎn)會(huì)生成當(dāng)前線程活動(dòng)的快照。完整的線程導(dǎo)出報(bào)告里會(huì)包含應(yīng)用程序的每個(gè)線程。其中包含很多線程的特定信息,還有線程相關(guān)的阻塞和鎖狀態(tài)。
【請(qǐng)求端點(diǎn)】/threaddump
【測(cè)試】
Thread thread = new Thread(() -> { try { Thread.sleep(1000000); } catch (InterruptedException e) { e.printStackTrace(); } }, "測(cè)試線程"); thread.start();
/shutdown 優(yōu)雅的關(guān)閉應(yīng)用程序
/shutdown可以讓應(yīng)用服務(wù)優(yōu)雅的關(guān)閉,默認(rèn)是關(guān)閉的。假設(shè)你要關(guān)閉運(yùn)行中的應(yīng)用程序。比方說,在微服務(wù)架構(gòu)中,你有多個(gè)微服務(wù)應(yīng)用的實(shí)例運(yùn)行在云上,其中某個(gè)實(shí)例有問題了,你決定關(guān)閉該實(shí)例并重啟這個(gè)有問題的應(yīng)用程序。在這個(gè)場(chǎng)景中,Actuator的/shutdown端點(diǎn)就很有用了。
優(yōu)雅的關(guān)閉和kill -9的方式是相對(duì)的,它不會(huì)粗暴的立馬關(guān)閉應(yīng)用,而是會(huì)釋放相關(guān)鏈接以及執(zhí)行SpringBoot容器停止后的一些操作,然后再關(guān)閉應(yīng)用。
【端點(diǎn)】/actuator/shutdown 要求POST請(qǐng)求方式
【示例】
在應(yīng)用中添加一個(gè)關(guān)閉前處理的鉤子方法
Runtime.getRuntime().addShutdownHook(new Thread(() -> { System.out.println("關(guān)閉應(yīng)用,釋放資源"); }));
可以看到通過/actuator/shutdown關(guān)閉應(yīng)用可以觸發(fā)這些關(guān)閉處理的鉤子函數(shù),方便我們?cè)趹?yīng)用停止時(shí)關(guān)閉一些連接以及做一些其他的處理。
整理
【1】上面實(shí)踐了一些Actuator端點(diǎn)示例,雖然Actuator提供的功能很強(qiáng)大,但是在如今的集群化,K8S容器化應(yīng)用部署下,這些直接訪問某些應(yīng)用的情況就變得很少了,比如監(jiān)控Zipkin 、Spring Cloud Sleuth等等,內(nèi)存監(jiān)控這一塊K8S容器化平臺(tái)也有很多。但是,去學(xué)習(xí)實(shí)踐這樣的一個(gè)工具也是很值得的,如果后面有類似監(jiān)控、關(guān)閉應(yīng)用、獲取請(qǐng)求URL映射、獲取配置等等,那么我們就可以去看看Actuator是如何做的,學(xué)習(xí)和擴(kuò)展。
【2】本次的學(xué)習(xí)時(shí)看的《SpringBoot實(shí)戰(zhàn)》書籍的學(xué)習(xí)筆記,該書Actuator章節(jié)后在后面也提及了很多進(jìn)階的知識(shí),因?yàn)榫唧w應(yīng)用場(chǎng)景不多,下面就簡(jiǎn)單的整理下,把一些知識(shí)點(diǎn)記錄下來,如果后面需要在重點(diǎn)實(shí)踐學(xué)習(xí)下。
【3】《SpringBoot實(shí)戰(zhàn)》書籍關(guān)于Actuator介紹的一些使用可能在當(dāng)下的版本中有些出入,這里貼上官方文檔地址,參考對(duì)比下https://docs.spring.io/spring-boot/docs/current/reference/html/actuator.html#actuator.enabling
【4】Actuator通過REST端點(diǎn)提供了不少非常有用的信息。另一個(gè)深入運(yùn)行中應(yīng)用程序內(nèi)部的方式是使用遠(yuǎn)程shell。Spring Boot集成了CRaSH,一種能嵌入任意Java應(yīng)用程序的shell。Spring Boot還擴(kuò)展了CRaSH,添加了不少Spring Boot特有的命令,提供了與Actuator端點(diǎn)類似的功能。該工具附上應(yīng)用上,會(huì)在啟動(dòng)時(shí)提供一個(gè)訪問秘鑰,我們通過ssh user@localhost -p 2000 的方式就可以去訪問,并且執(zhí)行一些命令去查看應(yīng)用數(shù)據(jù)。
【5】除了REST端點(diǎn)和遠(yuǎn)程shell,Actuator還把它的端點(diǎn)以MBean的方式發(fā)布了出來,可以通過JMX來查看和管理。使用JMX是管理Spring Boot應(yīng)用程序的一個(gè)好方法,如果你已在用JMX管理應(yīng)用程序中的其他MBean,則尤其如此。
【6】前面我們使用了Actuator所提供好的一些內(nèi)置端點(diǎn),我們也可以根據(jù)自己的需求擴(kuò)展定制Actuator。
- 實(shí)際上,Actuator有多種定制方式,包括以下五項(xiàng)。
- 1:重命名端點(diǎn)。將默認(rèn)的端點(diǎn)修改為我們自定義的端點(diǎn)地址。
- 2:?jiǎn)⒂煤徒枚它c(diǎn)。
- 3:自定義度量信息。
- 4:創(chuàng)建自定義倉(cāng)庫(kù)來存儲(chǔ)跟蹤數(shù)據(jù)。
- 5:插入自定義的健康指示器。
【7】到這里我們可以看到通過Actuator我們可以看到系統(tǒng)的很多信息,這對(duì)于開發(fā)者而言很好,但是在安全層面來說,如果不加以限制,那么系統(tǒng)的安全將會(huì)有很大隱患。Actuator的端點(diǎn)保護(hù)可以用和其他URL路徑一樣的方式——使用Spring Security。在Spring Boot應(yīng)用程序中,這意味著將Security起步依賴作為構(gòu)建依賴加入,然后讓安全相關(guān)的自動(dòng)配置來保護(hù)應(yīng)用程序,其中當(dāng)然也包括了Actuator端點(diǎn)。舉例來說,你想要保護(hù)/shutdown端點(diǎn),僅允許擁有ADMIN權(quán)限的用戶訪問
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Mybatis 一對(duì)多和多對(duì)一關(guān)聯(lián)查詢問題
這篇文章主要介紹了Mybatis 一對(duì)多和多對(duì)一關(guān)聯(lián)查詢問題,需要的朋友可以參考下2017-04-04java案例實(shí)戰(zhàn)之字符串轉(zhuǎn)換為二進(jìn)制
最近遇到個(gè)需求,要求編寫一個(gè)程序,從鍵盤錄入一個(gè)字符串,將字符串轉(zhuǎn)換為二進(jìn)制數(shù),下面這篇文章主要給大家介紹了關(guān)于java字符串轉(zhuǎn)換為二進(jìn)制的相關(guān)資料,需要的朋友可以參考下2023-06-06解決bufferedReader.readLine()讀到最后發(fā)生阻塞的問題
這篇文章主要介紹了解決bufferedReader.readLine()讀到最后發(fā)生阻塞的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07SpringBoot異步實(shí)現(xiàn) 的8種方式
在同步操作中,執(zhí)行到?發(fā)送短信?的時(shí)候,我們必須等待這個(gè)方法徹底執(zhí)行完才能執(zhí)行?贈(zèng)送積分?這個(gè)操作,如果?贈(zèng)送積分?這個(gè)動(dòng)作執(zhí)行時(shí)間較長(zhǎng),發(fā)送短信需要等待,這就是典型的同步場(chǎng)景,這篇文章主要介紹了SpringBoot異步實(shí)現(xiàn) 的8種方式,需要的朋友可以參考下2023-11-11Mybatis-Plus進(jìn)階分頁與樂觀鎖插件及通用枚舉和多數(shù)據(jù)源詳解
這篇文章主要介紹了Mybatis-Plus的分頁插件與樂觀鎖插件還有通用枚舉和多數(shù)據(jù)源的相關(guān)介紹,文中代碼附有詳細(xì)的注釋,感興趣的朋友來看看吧2022-03-03IntelliJ IDEA遠(yuǎn)程Debug Linux的Java程序,找問題不要只會(huì)看日志了(推薦)
這篇文章主要介紹了IntelliJ IDEA遠(yuǎn)程Debug Linux的Java程序,找問題不要只會(huì)看日志了,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09使用CXF和Jersey框架來進(jìn)行Java的WebService編程
這篇文章主要介紹了使用CXF和Jersey框架來進(jìn)行Java的WebService編程,Web service是一個(gè)平臺(tái)獨(dú)立的低耦合的自包含的基于可編程的web的應(yīng)用程序,需要的朋友可以參考下2015-12-12