管理SpringBoot項目的三個強大的功能是否用過?
環境:SpringBoot2.7.18
1. 管理功能Admin Features
通過指定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
圖片
2. 應用退出
每個SpringApplication都向JVM注冊一個關閉掛鉤,以確保ApplicationContext在退出時正常關閉。所有標準的Spring生命周期回調(如DisposableBean接口或@PreDestroy注釋)都可以使用。
2.1 自定義退出碼
@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注解他們對應的回調方法都執行。
2.2 自定義DisposableBean
@Component
public class AppComponent implements DisposableBean {
@Override
public void destroy() throws Exception {
System.out.println("Bean生命周期結束...") ;
}
}
2.3 定義exit接口
@Resource
private ConfigurableApplicationContext context ;
@GetMapping("")
public Object exit() {
SpringApplication.exit(context) ;
return "exit" ;
}
2.4 測試
調用上的接口后,你將在控制臺看到如下輸出
圖片
在關閉應用程序之前SpringBoot會發布ExitCodeEvent事件
@Component
public class PackAppExitListener implements ApplicationListener<ExitCodeEvent> {
@Override
public void onApplicationEvent(ExitCodeEvent event) {
System.out.printf("監聽到應用退出事件,退出碼:%d%n", event.getExitCode()) ;
}
}
結果輸出:
圖片
3. 應用啟動跟蹤
在應用程序啟動期間,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,在自己的業務代碼中進行監控。
@Resource
private ApplicationStartup startup ;
這樣你就可以進行start和end方法調用進行記錄監控了。