1. 程式人生 > 程式設計 >Spring Boot Admin微服務應用監控的實現

Spring Boot Admin微服務應用監控的實現

Spring Boot Admin 可以對SpringBoot應用的各項指標進行監控,可以作為微服務架構中的監控中心來使用,本文將對其用法進行詳細介紹。

Spring Boot Admin 簡介

SpringBoot應用可以通過Actuator來暴露應用執行過程中的各項指標,Spring Boot Admin通過這些指標來監控SpringBoot應用,然後通過圖形化介面呈現出來。Spring Boot Admin不僅可以監控單體應用,還可以和Spring Cloud的註冊中心相結合來監控微服務應用。

Spring Boot Admin 可以提供應用的以下監控資訊:

  • 監控應用執行過程中的概覽資訊;
  • 度量指標資訊,比如JVM、Tomcat及程序資訊;
  • 環境變數資訊,比如系統屬性、系統環境變數以及應用配置資訊;
  • 檢視所有建立的Bean資訊;
  • 檢視應用中的所有配置資訊;
  • 檢視應用執行日誌資訊;
  • 檢視JVM資訊;
  • 檢視可以訪問的Web端點;
  • 檢視HTTP跟蹤資訊。

這裡我們建立一個admin-server模組來作為監控中心演示其功能。

在pom.xml中新增相關依賴:

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
 <groupId>de.codecentric</groupId>
 <artifactId>spring-boot-admin-starter-server</artifactId>
</dependency>

在application.yml中進行配置:

spring:
 application:
 name: admin-server
server:
 port: 9301

在啟動類上新增@EnableAdminServer來啟用admin-server功能:

@EnableAdminServer
@SpringBootApplication
public class AdminServerApplication {

 public static void main(String[] args) {
 SpringApplication.run(AdminServerApplication.class,args);
 }

}

建立admin-client模組

這裡我們建立一個admin-client模組作為客戶端註冊到admin-server。

在pom.xml中新增相關依賴:

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
 <groupId>de.codecentric</groupId>
 <artifactId>spring-boot-admin-starter-client</artifactId>
</dependency>

在application.yml中進行配置:

spring:
 application:
 name: admin-client
 boot:
 admin:
 client:
 url: http://localhost:9301 #配置admin-server地址
server:
 port: 9305
management:
 endpoints:
 web:
 exposure:
 include: '*'
 endpoint:
 health:
 show-details: always
logging:
 file: admin-client.log #新增開啟admin的日誌監控

啟動admin-server和admin-client服務。

監控資訊演示

訪問如下地址開啟Spring Boot Admin的主頁: http://localhost:9301

點選wallboard按鈕,選擇admin-client檢視監控資訊;

監控資訊概覽;

度量指標資訊,比如JVM、Tomcat及程序資訊;

環境變數資訊,比如系統屬性、系統環境變數以及應用配置資訊;

檢視所有建立的Bean資訊;

檢視應用中的所有配置資訊;

檢視日誌資訊,需要新增以下配置才能開啟;

logging:
 file: admin-client.log #新增開啟admin的日誌監控

檢視JVM資訊;

檢視可以訪問的Web端點;

檢視HTTP跟蹤資訊;

結合註冊中心使用

Spring Boot Admin結合Spring Cloud 註冊中心使用,只需將admin-server和註冊中心整合即可,admin-server 會自動從註冊中心獲取服務列表,然後挨個獲取監控資訊。這裡以Eureka註冊中心為例來介紹下該功能。

修改admin-server 在pom.xml中新增相關依賴:

<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

在application-eureka.yml中進行配置,只需添加註冊中心配置即可:

spring:
 application:
 name: admin-server
server:
 port: 9301
eureka:
 client:
 register-with-eureka: true
 fetch-registry: true
 service-url:
  defaultZone: http://localhost:8001/eureka/

在啟動類上新增@EnableDiscoveryClient來啟用服務註冊功能:

@EnableDiscoveryClient
@EnableAdminServer
@SpringBootApplication
public class AdminServerApplication {

 public static void main(String[] args) {
  SpringApplication.run(AdminServerApplication.class,args);
 }

}

修改admin-client

在pom.xml中新增相關依賴:

<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

在application-eureka.yml中進行配置,刪除原來的admin-server地址配置,添加註冊中心配置即可:

spring:
 application:
 name: admin-client
server:
 port: 9305
management:
 endpoints:
 web:
  exposure:
  include: '*'
 endpoint:
 health:
  show-details: always
logging:
 file: admin-client.log #新增開啟admin的日誌監控
eureka:
 client:
 register-with-eureka: true
 fetch-registry: true
 service-url:
  defaultZone: http://localhost:8001/eureka/

在啟動類上新增@EnableDiscoveryClient來啟用服務註冊功能:

@EnableDiscoveryClient
@SpringBootApplication
public class AdminClientApplication {

 public static void main(String[] args) {
  SpringApplication.run(AdminClientApplication.class,args);
 }

}

功能演示

啟動eureka-server,使用application-eureka.yml配置啟動admin-server,admin-client;

檢視註冊中心發現服務均已註冊: http://localhost:8001/

檢視Spring Boot Admin 主頁發現可以看到服務資訊: http://localhost:9301

新增登入認證

我們可以通過給admin-server新增Spring Security支援來獲得登入認證功能。

建立admin-security-server模組

在pom.xml中新增相關依賴:

<dependency>
 <groupId>org.springframework.cloud</groupId>
 <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
 <groupId>de.codecentric</groupId>
 <artifactId>spring-boot-admin-starter-server</artifactId>
 <version>2.1.5</version>
</dependency>
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-web</artifactId>
</dependency>

在application.yml中進行配置,配置登入使用者名稱和密碼,忽略admin-security-server的監控資訊:

spring:
 application:
 name: admin-security-server
 security: # 配置登入使用者名稱和密碼
 user:
  name: macro
  password: 123456
 boot: # 不顯示admin-security-server的監控資訊
 admin:
  discovery:
  ignored-services: ${spring.application.name}
server:
 port: 9301
eureka:
 client:
 register-with-eureka: true
 fetch-registry: true
 service-url:
  defaultZone: http://localhost:8001/eureka/

對SpringSecurity進行配置,以便admin-client可以註冊:

/**
 * Created by macro on 2019/9/30.
 */
@Configuration
public class SecuritySecureConfig extends WebSecurityConfigurerAdapter {
 private final String adminContextPath;

 public SecuritySecureConfig(AdminServerProperties adminServerProperties) {
  this.adminContextPath = adminServerProperties.getContextPath();
 }

 @Override
 protected void configure(HttpSecurity http) throws Exception {
  SavedRequestAwareAuthenticationSuccessHandler successHandler = new SavedRequestAwareAuthenticationSuccessHandler();
  successHandler.setTargetUrlParameter("redirectTo");
  successHandler.setDefaultTargetUrl(adminContextPath + "/");

  http.authorizeRequests()
    //1.配置所有靜態資源和登入頁可以公開訪問
    .antMatchers(adminContextPath + "/assets/**").permitAll()
    .antMatchers(adminContextPath + "/login").permitAll()
    .anyRequest().authenticated()
    .and()
    //2.配置登入和登出路徑
    .formLogin().loginPage(adminContextPath + "/login").successHandler(successHandler).and()
    .logout().logoutUrl(adminContextPath + "/logout").and()
    //3.開啟http basic支援,admin-client註冊時需要使用
    .httpBasic().and()
    .csrf()
    //4.開啟基於cookie的csrf保護
    .csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse())
    //5.忽略這些路徑的csrf保護以便admin-client註冊
    .ignoringAntMatchers(
      adminContextPath + "/instances",adminContextPath + "/actuator/**"
    );
 }
}

修改啟動類,開啟AdminServer及註冊發現功能:

@EnableDiscoveryClient
@EnableAdminServer
@SpringBootApplication
public class AdminSecurityServerApplication {

 public static void main(String[] args) {
  SpringApplication.run(AdminSecurityServerApplication.class,args);
 }

}

啟動eureka-server,admin-security-server,訪問Spring Boot Admin 主頁發現需要登入才能訪問: http://localhost:9301

使用到的模組

springcloud-learning
├── eureka-server -- eureka註冊中心
├── admin-server -- admin監控中心服務
├── admin-client -- admin監控中心監控的應用服務
└── admin-security-server -- 帶登入認證的admin監控中心服務

專案原始碼地址

https://github.com/macrozheng/springcloud-learning

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。