springboot2 admin的使用

前情提要】Spring Boot Actuator 提供了對單個 Spring Boot 應用的監控,信息包含應用狀態、內存、線程、堆棧等,比較全面的監控了 Spring Boot 應用的整個生命週期。但是這樣監控也有一些問題:第一,所有的監控都需要調用固定的接口來查看,如果全面查看應用狀態需要調用很多接口,並且接口返回的 JSON 信息不方便運營人員理解;第二,如果 Spring Boot 應用集羣非常大,每個應用都需要調用不同的接口來查看監控信息,操作非常繁瑣低效。在這樣的背景下,就誕生了另外一個開源軟件:Spring Boot Admin

 

1. 什麼是Spring Boot Admin

Spring Boot Admin 是一個管理和監控 Spring Boot 應用程序的開源軟件,每個應用都認爲是一個客戶端,通過 HTTP 或者使用 Eureka 註冊到 admin server 中進行展示,Spring Boot Admin UI 部分使用 Vue.js 將數據展示在前端。

Spring Boot Admin 是一個針對 Spring Boot 的 Actuator 接口進行 UI 美化封裝的監控工具,它可以在列表中瀏覽所有被監控 spring-boot 項目的基本信息、詳細的 Health 信息、內存信息、JVM 信息、垃圾回收信息、各種配置信息(比如數據源、緩存列表和命中率)等,還可以直接修改 logger 的 level。

值得注意的是 Spring Boot Admin 並不是 Spring Boot 官方出品的開源軟件,但是其軟件質量和使用廣泛度都非常的高,並且 Spring Boot Admin 會及時隨着 Spring Boot 的更新而更新,當 Spring Boot 推出 2.X 版本時 Spring Boot Admin 也及時進行了更新。

Spring Boot Admin 2.x 不僅是跟着支持了 Spring Boot 2.x,還在 1.x 的基礎上進行了大量的更新和優化:

重新規劃了項目依賴包,讓項目中更方便的集成 Spring Boot Admin

1.x 前端使用了 Angular.js,2.x 使用 Vue 對界面進行了重寫,界面美觀度提升幅度非常高

提供了支持 Spring Cloud 的組件

其他更新,具體參考:Changes with 2.x

Spring Boot Admin 分爲服務端和客戶端,服務端其實就是一個監控後臺用來彙總展示所有的監控信息,客戶端就是我們的應用,使用時需要先啓動服務端,在啓動客戶端的時候打開 Actuator 的接口,並指向服務端的地址,這樣服務端會定時讀取相關信息以達到監控的目的。


接下來演示如何使用 Spring Boot Admin 對 Spring Boot 應用進行監控。

 

2. 監控單體應用(最簡單的入門)

先給大家展示如何使用 Spring Boot Admin 監控單個 Spring Boot 應用。

Admin Server 端

項目依賴

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

2.x 下只需要添加此一個包即可,其他組件會自動依賴添加。

配置文件

#配置服務端口號

server.port=8000

服務端設置端口爲:8000

啓動類

@EnableAdminServer
@SpringBootApplication
public class AdminServerApplication {

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

完成上面三步之後,啓動服務端,訪問網址 http://localhost:8000 可以看到界面

因爲剛啓動沒有應用,因此顯示:No applications registered.,同時根據上圖也可以看出 applications 頁面會展示項目的應用數、實例數和狀態三個信息。

接下來我們構建一個客戶端,並註冊到服務端。

 

Admin Client 端

項目依賴

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

添加 spring-boot-starter-web 是爲了使應用處於啓動狀態,spring-boot-admin-starter-client 會自動添加 Actuator 相關依賴。

#配置服務端口號
server.port=9000
#配置該服務的實例名稱(每個服務集羣的共用名稱,也就是服務集羣的名稱)
spring.application.name=providerService
spring.boot.admin.client.url=http://localhost:8000
management.endpoints.web.exposure.include=*
management.endpoint.health.show-details=always

 

啓動類

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

配置完成之後,啓動 Client 端,Admin 服務端會自動檢查到客戶端的變化

 

關掉client 會有提示

 

3. 監控微服務

如果我們使用的是單個 Spring Boot 應用,就需要在每一個被監控的應用中配置 Admin Server 的地址信息;如果應用都註冊在 Eureka 中就不需要再對每個應用進行配置,Spring Boot Admin 會自動從註冊中心抓取應用的相關信息。

如果使用了 Spring Cloud 的服務發現功能,就不需要再單獨添加 Admin Client 客戶端,僅僅需要 Spring Boot Server,其他內容會自動進行配置。

接下來以 Eureka 作爲服務發現的示例來進行演示,實際上也可以使用 Consul 或者 Zookeeper。

(1)服務端和客戶端添加 spring-cloud-starter-eureka 到包依賴中

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

(2)啓動類添加註解

@Configuration
@EnableAutoConfiguration
@EnableDiscoveryClient
@EnableAdminServer
public class SpringBootAdminApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringBootAdminApplication.class, args);
    }

    @Configuration
    public static class SecurityPermitAllConfig extends WebSecurityConfigurerAdapter {
        @Override
        protected void configure(HttpSecurity http) throws Exception {
            http.authorizeRequests().anyRequest().permitAll()  
                .and().csrf().disable();
        }
    }
}

使用類 SecurityPermitAllConfig 關閉了安全驗證。

(3)在客戶端中配置服務發現的地址

eureka:   
  instance:
    leaseRenewalIntervalInSeconds: 10
    health-check-url-path: /actuator/health
    metadata-map:
      startup: ${random.int}    #needed to trigger info and endpoint update after restart
  client:
    registryFetchIntervalSeconds: 5
    serviceUrl:
      defaultZone: ${EUREKA_SERVICE_URL:http://localhost:8761}/eureka/

management:
  endpoints:
    web:
      exposure:
        include: "*"  
  endpoint:
    health:
      show-details: ALWAYS

Spring Cloud 提供了示例代碼可以參考這裏:spring-boot-admin-sample-eureka

重啓啓動服務端和客戶端之後,訪問服務端的相關地址就可以看到監控頁面了。

4.安全控制

Spring Boot Admin 後臺有很多的敏感信息和操作,如果公司不做權限控制可能會影響到公司系統的安全性。Spring Boot Admin 也考慮到了這個因素,可以利用前面的 Spring Security 做安全訪問控制,在 spring-boot-admin-server 上進行改造。

(1)添加 Spring Boot Security 依賴包

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-security</artifactId>
</dependency>

(2)添加安全訪問控制

和前面的 Security 配置一樣,給項目添加訪問控制

@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 {
        // @formatter:off
        SavedRequestAwareAuthenticationSuccessHandler successHandler = new SavedRequestAwareAuthenticationSuccessHandler();
        successHandler.setTargetUrlParameter("redirectTo");
        successHandler.setDefaultTargetUrl(adminContextPath + "/");

        http.authorizeRequests()
            .antMatchers(adminContextPath + "/assets/**").permitAll() 
            .antMatchers(adminContextPath + "/login").permitAll()
            .anyRequest().authenticated() 
            .and()
        .formLogin().loginPage(adminContextPath + "/login").successHandler(successHandler).and() 
        .logout().logoutUrl(adminContextPath + "/logout").and()
        .httpBasic().and() 
        .csrf()
            .csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse())  
            .ignoringAntMatchers(
                adminContextPath + "/instances",   
                adminContextPath + "/actuator/**"  
            );
    }
}
antMatchers(adminContextPath + "/assets/**").permitAll() 所有靜態內容不做安全驗證
anyRequest().authenticated() 其他請求均需要驗證
formLogin() 配置登錄
logout() 配置登出
httpBasic() 支持 HTTP,引導 Spring Boot Admin 客戶端註冊

csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse()) 
打開跨站點請求保護 Cookies
    adminContextPath + "/instances" 
取消跨站點請求保護 "/instances",方便 Admin 客戶端註冊
    adminContextPath + "/actuator/** " 
取消跨站點請求保護 "/actuator/**",可以讓 Admin 監控到 Actuator 的相關接口

然後可以給 security 設置一個用戶名和密碼:
spring.security.user.name=admin
spring.security.user.password=admin
配置完成之後重啓 Admin Server 端,訪問網址 http://localhost:8000 
就會發現需要一個登錄的用戶名和密碼了。


 

使用剛纔設置的用戶名和密碼登錄之後,發現註冊到 Server 端的服務數成爲 0 了,這是客戶端統一也需要配置帳戶名和密碼信息。

spring.security.user.name=admin
spring.security.user.password=admin
配置完成之後重新啓動,在服務端就又可以查看監控到的應用了。

5.其他方式

如果 Actuator 的端口被使用 HTTP 認證保護,那麼 Spring Boot Admin Server 訪問的時候需要憑證信息,這時候可以使用 metadata 的方式對賬戶和密碼進行配置。

直接使用客戶端註冊的方式:

spring.boot.admin.client:
    url: http://localhost:8080
    instance:
      metadata:
        user.name: ${spring.security.user.name}
        user.password: ${spring.security.user.password}

使用 Eureka 進行註冊的方式:

eureka:
  instance:
    metadata-map:
      user.name: ${spring.security.user.name}
      user.password: ${spring.security.user.password}

Eureka 中的 metadataMap 是專門用來存放一些自定義的數據,當註冊中心或者其他服務需要此服務的某些配置時可以在 metadataMap 裏取。實際上,每個 instance 都有各自的 metadataMap,map 中存放着需要用到的屬性。例如,上面配置中的 eureka.instance.metadata-map.user.name,當這個服務成功註冊到 Eureka 上,Spring Boot Admin 就會拿到這個 instance,進而拿到 metadataMap 裏的屬性,然後放入請求頭,向此服務發送請求,訪問此服務的 Actuator 開放的端點。

6.郵件告警

Spring Boot Admin 將微服務中所有應用信息在後臺進行了展示,非常方便我們對微服務整體的監控和治理。但是我們的運營人員也不可能一天 24 小時盯着監控後臺,因此如果服務有異常的時候,有對應的郵件告警就太好了,其實 Spring Boot Admin 也給出了支持。

我們對上面的示例項目 spring-boot-admin-server 進行改造。

添加依賴

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-mail</artifactId>
</dependency>

增加了郵件發送的 starter 包。

配置文件

spring.mail.host=smtp.qq.com
[email protected]
spring.mail.password=xxx
spring.mail.properties.mail.smtp.auth=true
spring.mail.properties.mail.smtp.starttls.enable=true
spring.mail.properties.mail.smtp.starttls.required=true
[email protected]
[email protected]

在配置文件中添加郵件發送相關信息:郵件的發送者、接受者、協議、移動授權碼等

配置完成後,重新啓動項目 spring-boot-admin-server,這樣 Admin Server 就具備了郵件告警的功能,默認情況下 Admin Server 對 Eureka 中的服務上下線都進行了監控,當服務上下線的時候我們就會收到相應的告警郵件。

當然這只是最基本的郵件監控,在實際的使用過程中,需要根據情況對郵件告警內容進行自定義,比如監控堆內存的使用情況,當到達一定比例的時候進行告警等。

【寫在後面的話】Spring Boot Admin 解決了我們對大規模 Spring Boot 應用監控的需求,Spring Boot Admin 充分利用了 Actuator 開放的相關接口,採用優秀的圖形界面將這些信息進行了展示,方便我們更加直觀的查看集羣中應用的狀態。Spring Boot Admin 不僅可以監控單個 Spring Boot 應用,也可以結合 Spring Cloud 監控註冊到服務中心的所有應用狀態,再結合報警系統的使用就可以隨時感知到應用的狀態變化。在實際工作中 Spring Boot Admin 是我們在後期運營中頻繁用到的一個組件,應該作爲重點關注。


最後是一個用http方式監聽的demo:Spring Boot Admin使用http連接server端

 

前半部分是我自己寫的, 後半部分是從別人那裏複製的.

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章