欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于Spring Cloud健康檢查的陷阱

 更新時(shí)間:2021年07月23日 09:27:35   作者:tom3mao  
這篇文章主要介紹了關(guān)于Spring Cloud健康檢查的陷阱,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

SpringCloud健康檢查的陷阱

健康檢查

基于Spring Boot Actuator的健康檢查是Spring Cloud微服務(wù)的必備組件,用來(lái)確保我們的服務(wù)是否可用。

引入 Spring Boot Actuator后,通過(guò)http://ip:port/health ,可以看到 HealthEndPoint 給我們提供默認(rèn)的監(jiān)控結(jié)果,包含磁盤檢測(cè)和數(shù)據(jù)庫(kù)檢測(cè)。如下

{
    "status": "UP",
    "diskSpace": {
        "status": "UP",
        "total": 398458875904,
        "free": 315106918400,
        "threshold": 10485760
    },
    "db": {
        "status": "UP",
        "database": "MySQL",
        "hello": 1
    }
}

排除不必要的健康檢查項(xiàng)

有一天調(diào)用方突然反饋調(diào)不通我們的服務(wù)。查看Eureka控制臺(tái),發(fā)現(xiàn)服務(wù)狀態(tài)是UP。查看服務(wù)進(jìn)程一切正常。束手無(wú)策之際,忽然想到會(huì)不會(huì)是健康檢查在作怪,因?yàn)镋ureka Client判斷服務(wù)可用與否的依據(jù)就是健康檢查。而Spring Boot Actuator所有的監(jiān)控項(xiàng)中的任何一個(gè)健康狀態(tài)是DOWN,那個(gè)整體應(yīng)用的健康狀態(tài)也是DOWN,這時(shí)候調(diào)用方就把服務(wù)當(dāng)作不可用。

再次查看http://ip:port/health,果然發(fā)現(xiàn)有一項(xiàng)郵件健康檢查掛了。

最近項(xiàng)目引入了spring-boot-starter-mail,實(shí)現(xiàn)發(fā)送郵件的功能。

郵箱服務(wù)器掛了,造成整個(gè)服務(wù)的監(jiān)控檢查狀態(tài)是DOWN。

{
  "status": "DOWN",
  "mail": {
    "status": "DOWN",
    "location": "email-smtp.test.com:-1",
    "error": "javax.mail.AuthenticationFailedException: 535 Authentication Credentials Invalid\n"
  },
  "diskSpace": {
    "status": "UP",
    "total": 266299998208,
    "free": 146394308608,
    "threshold": 10485760
  },
  "hystrix": {
    "status": "UP"
  }
}

由于郵件發(fā)送不是核心功能,可以把非核心組件從健康檢查中排除,避免造成整個(gè)服務(wù)不可用。

通過(guò)如下配置關(guān)閉郵箱健康檢查。

management.health.mail.enabled=false

springcloud-health檢查超時(shí)引發(fā)的大坑

0. 前提約定

service:只一個(gè)微服務(wù)

server:只提供一個(gè)微服務(wù)的app,一般一個(gè)service有多個(gè)server。

1. 問(wèn)題介紹

線上springcloud遇到這樣的問(wèn)題:某些時(shí)候會(huì)移除某個(gè)service的所有server。

2. 原因分析

springcloud中默認(rèn)使用springboot-actauctor的health-url作為健康檢測(cè),默認(rèn)檢查的超時(shí)時(shí)間為10s,如果生產(chǎn)環(huán)境遇到網(wǎng)絡(luò)、db、redis慢或者掛了等問(wèn)題,會(huì)導(dǎo)致health檢查請(qǐng)求超時(shí),springcloud注冊(cè)中心會(huì)認(rèn)為該server異常,從而將server狀態(tài)變更為critial,服務(wù)調(diào)用方(feign)會(huì)將該異常server從負(fù)載中移除(HealthServiceServerListFilter)。

如果遇到某網(wǎng)段或更大規(guī)模的網(wǎng)絡(luò)、db等問(wèn)題,會(huì)導(dǎo)致某個(gè)service所有server都被注冊(cè)中心移除,導(dǎo)致該service不可用。

但是實(shí)際上該server只是存在部分問(wèn)題例如:僅僅是db或redis慢,不算不可用,但還是被注冊(cè)中心強(qiáng)制摘除了。

3. 解決辦法

3.1 通用解決辦法

關(guān)閉health檢查,永遠(yuǎn)返回up狀態(tài),只要程序正常啟動(dòng)就認(rèn)為可以提供正常服務(wù)。

如下是項(xiàng)目模板輸出默認(rèn)的health檢查結(jié)果:

{
 "description": "",
 "status": "UP",
 "diskSpace": {
  "description": "",
  "status": "UP",
  "total": 50715856896,
  "free": 7065239552,
  "threshold": 10485760
 },
 "solr": {
  "description": "",
  "status": "UP",
  "solrStatus": "OK"
 },
 "redis": {
  "description": "",
  "status": "UP",
  "version": "2.8.21"
 },
 "db": {
  "description": "",
  "status": "UP",
  "authDataSource": {
   "description": "",
   "status": "UP",
   "database": "MySQL",
   "hello": "x"
  },
  "autodealerDataSource": {
   "description": "",
   "status": "UP",
   "database": "Microsoft SQL Server",
   "hello": "x"
  }
 }
}

關(guān)閉health檢查的方法:

# application*.yml中
management:
  health:
    defaults:
      enabled: false

關(guān)閉后health檢查結(jié)果:

{
 "description": "",
 "status": "UP",
 "application": {
  "description": "",
  "status": "UP"
 }
}

4. 如果有特定health檢查的需求

關(guān)閉health檢查后,如果需要某類health檢查需求,則需要單獨(dú)配置,配置方法如下:

management:
  health:
    defaults:
      enabled: false
    # 如下配置則打開(kāi)db-health檢查
    db:
      enabled: true

health檢查結(jié)果如下:

{
 "description": "",
 "status": "UP",
 "db": {
  "description": "",
  "status": "UP",
  "authDataSource": {
   "description": "",
   "status": "UP",
   "database": "MySQL",
   "hello": "x"
  },
  "autodealerDataSource": {
   "description": "",
   "status": "UP",
   "database": "Microsoft SQL Server",
   "hello": "x"
  }
 }
}

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • idea 訪問(wèn)html頁(yè)面端口號(hào)顯示的是63342而不是8080

    idea 訪問(wèn)html頁(yè)面端口號(hào)顯示的是63342而不是8080

    這篇文章主要介紹了idea 訪問(wèn)html頁(yè)面端口號(hào)顯示的是63342而不是8080,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 基于swing實(shí)現(xiàn)窗體拖拽和拉伸

    基于swing實(shí)現(xiàn)窗體拖拽和拉伸

    這篇文章主要為大家詳細(xì)介紹了基于swing實(shí)現(xiàn)窗體拖拽和拉伸,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • Spring事務(wù)框架之TransactionDefinition源碼解析

    Spring事務(wù)框架之TransactionDefinition源碼解析

    這篇文章主要為大家介紹了Spring事務(wù)框架之TransactionDefinition源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • MyBatis中SqlSession生命周期的使用

    MyBatis中SqlSession生命周期的使用

    SqlSession是MyBatis的核心接口之一,本文主要介紹了MyBatis中SqlSession生命周期的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-09-09
  • Java實(shí)現(xiàn)動(dòng)態(tài)驗(yàn)證碼生成

    Java實(shí)現(xiàn)動(dòng)態(tài)驗(yàn)證碼生成

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)動(dòng)態(tài)驗(yàn)證碼生成,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 深入理解JVM垃圾回收算法

    深入理解JVM垃圾回收算法

    我們都知道java語(yǔ)言與C語(yǔ)言最大的區(qū)別就是內(nèi)存自動(dòng)回收,那么JVM是怎么控制內(nèi)存回收的,這篇文章將介紹JVM垃圾回收的幾種算法,從而了解內(nèi)存回收的基本原理
    2021-06-06
  • JAVA實(shí)現(xiàn)簡(jiǎn)單系統(tǒng)登陸注冊(cè)模塊

    JAVA實(shí)現(xiàn)簡(jiǎn)單系統(tǒng)登陸注冊(cè)模塊

    這篇文章主要介紹了一個(gè)簡(jiǎn)單完整的登陸注冊(cè)模塊的實(shí)現(xiàn)過(guò)程,文章條理清晰,在實(shí)現(xiàn)過(guò)程中加深了對(duì)相關(guān)概念的理解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2015-07-07
  • 一文帶你深入了解Java?TreeMap

    一文帶你深入了解Java?TreeMap

    TreeMap是Map家族中的一員,也是用來(lái)存放key-value鍵值對(duì)的。平時(shí)在工作中使用的可能并不多。本文將基于jdk8對(duì)其做一個(gè)講解,感興趣的可以了解一下
    2022-09-09
  • java實(shí)現(xiàn)簡(jiǎn)單日期計(jì)算功能

    java實(shí)現(xiàn)簡(jiǎn)單日期計(jì)算功能

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單日期計(jì)算功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • spring cloud openfeign 源碼實(shí)例解析

    spring cloud openfeign 源碼實(shí)例解析

    這篇文章主要介紹了spring cloud openfeign 源碼實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10

最新評(píng)論