環境:SpringBoot2.7.18
通過指定spring.application.admin.enabled屬性,可以為應用程序啟用管理員相關的功能。這在平臺MBeanServer上公開了SpringApplicationAdminMXBean。你可以使用這個特性遠程管理Spring Boot應用程序。
spring: application: admin: enabled: true
開啟管理功能后,你可以通過JConsole查看MBean對當前的SpringBoot程序進行簡單的管理及查看。默認JMX的名稱為:org.springframework.boot:type=Admin,name=SpringApplication
圖片
在操作菜單中,我們可以通過shutdown關閉應用程序,可以通過getProperty獲取應用中的配置屬性信息。
圖片
獲取屬性信息:
圖片
自定義JMX名稱:
spring: application: admin: enabled: true jmx-name: com.pack:type=AKF,name=PackAPP
注意:這里jmx-name格式:xxx:type=yyy,name=zzz
圖片
每個SpringApplication都向JVM注冊一個關閉掛鉤,以確保ApplicationContext在退出時正常關閉。所有標準的Spring生命周期回調(如DisposableBean接口或@PreDestroy注釋)都可以使用。
@Component@Order(-2)public class PackExitCodeGenerator implements ExitCodeGenerator { @Override public int getExitCode() { System.out.println("PackExitCodeGenerator exit code 6...") ; return 6 ; }}
你可以定義多個實現了ExitCodeGenerator的類,通過@Order定義順序,而SpringBoot只會返回第一個非零的退出碼。
SpringBoot的退出操作是調用當前容器ConfigurableApplicationContext#close方法。所以當前容器中所有實現了DisposableBean或使用了@PreDestory注解他們對應的回調方法都執行。
@Componentpublic class AppComponent implements DisposableBean { @Override public void destroy() throws Exception { System.out.println("Bean生命周期結束...") ; }}
@Resourceprivate ConfigurableApplicationContext context ;@GetMapping("")public Object exit() { SpringApplication.exit(context) ; return "exit" ;}
調用上的接口后,你將在控制臺看到如下輸出
圖片
在關閉應用程序之前SpringBoot會發布ExitCodeEvent事件
@Componentpublic class PackAppExitListener implements ApplicationListener<ExitCodeEvent> { @Override public void onApplicationEvent(ExitCodeEvent event) { System.out.printf("監聽到應用退出事件,退出碼:%d%n", event.getExitCode()) ; }}
結果輸出:
圖片
在應用程序啟動期間,SpringApplication和ApplicationContext執行許多與應用程序生命周期、bean生命周期甚至處理應用程序事件相關的任務。有了ApplicationStartup, Spring框架允許你用StartupStep對象跟蹤應用程序的啟動順序。收集這些數據可以用于分析,或者只是為了更好地了解應用程序啟動過程。
你可以在設置SpringApplication實例時選擇ApplicationStartup實現。例如,要使用BufferingApplicationStartup,如下示例:
SpringApplication application = new SpringApplication(SpringbootComprehensiveApplication.class) ;application.setApplicationStartup(new BufferingApplicationStartup(2048)) ;application.run(args) ;
接下來需要通過可以通過Actuator暴露的端口,以JSON的形式查看信息。引入依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId></dependency>
通過/startup接口查看Spring容器啟動過程的完整信息。
圖片
在你的項目中你還可以注入ApplicationStartup,在自己的業務代碼中進行監控。
@Resourceprivate ApplicationStartup startup ;
這樣你就可以進行start和end方法調用進行記錄監控了。
本文鏈接:http://www.www897cc.com/showinfo-26-98190-0.html管理SpringBoot項目的三個強大的功能是否用過?
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com