SpringBoot actuator 健康檢查不通過的解決方案

SpringBoot actuator 健康檢查不通過

今天遇到有個服務能夠註冊成功,但是健康檢查不通過,通過瀏覽器訪問健康檢查的url,chrome的network一直顯示pending,說明這個請求提交瞭,但是得不到返回,卡住瞭。

原來以為健康檢查就是檢查服務端口下的/health這個請求本身是否能正常返回,其實不是。

所謂健康檢查是有很多檢查項的,springboot中繼承AbstractHealthIndicator的類,比如DataSourceHealthIndicator RedisHealthIndicator 等,springboot會自動配置,比如使用瞭mysql的datasouce,健康檢查的時候就會執行DataSourceHealthIndicator 的doHealthCheck(),使用瞭redis,就會執行RedisHealthIndicator 的doHealthCheck()。

解決方式:

首先可以確定是否是這些外部數據源連接不瞭導致健康檢查不通過,可以配置

management:
  health:
    db:
      enabled: false
    redis:
      enabled: false
    elasticsearch:
      enabled: false

把系統中用到的都關閉健康檢查,看健康檢查是否能正常通過,如果能通過再一個個打開逐個排除問題

最終發現上面的pending情況就是由於mysql的url配置不對,比如端口錯誤,或者mysql用戶的權限不夠,DataSourceHealthIndicator 的doHealthCheck()會去連接mysql連接不成功,就卡在連接mysql那裡瞭。

配置正確的url,開啟權限,解決問題。

Spring Boot健康檢查相關配置和整理

1.什麼是Spring Boot的健康檢查,有什麼用?

Spring Boot提供瞭多項組件的健康檢查,有利於監控各組件運行狀況,但是有時開發者因此會啟動不成功,報錯等,需要合理配置。

2.Spring Boot項目中都有哪些檢查,如何配置相關檢查:

2.1首先健康檢查引入的包是

<dependency>
    <groupid>org.springframework.boot</groupid>
    <artifactid>spring-boot-starter-actuator</artifactid>
</dependency>

2.2相關健康檢查相關Indicator

  • CassandraHealthIndicator 檢查Cassandra是否可用
  • DiskSpaceHealthIndicator 檢查磁盤空間是否不足
  • DataSourceHealthIndicator 檢查能否從DataSource獲取鏈接
  • ElasticsearchHealthIndicator 檢查Elasticsearch cluste是否可用
  • JmsHealthIndicator 檢查JMS broker是否可用
  • MailHealthIndicator 檢查mail server是否可用
  • MongoHealthIndicator 檢查Mongo database是否可用
  • RabbitHealthIndicator 檢查Rabbit server是否可用
  • RedisHealthIndicator 檢查Redis server是否可用
  • SolrHealthIndicator 檢查Solr server是否可用

可以看到,有各項外部服務的檢查,具體的請瀏覽官方文檔,這裡不再贅餘

2.3如何關閉/開啟健康檢查

application.properties裡顯式設定

//如禁止es的健康檢查如下,默認均為開啟狀態
management.health.elasticsearch.enabled=false

也可以使用*全部禁止

management.health.*.enabled=false

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: