首先對eureka註冊中心需要了解的是eureka各個節點都是平等的,沒有zk中角色的概念, 即使n-1個節點掛掉也不會影響其他節點的正常執行。
預設情況下,如果eureka server在一定時間內(預設90秒)沒有接收到某個微服務例項的心跳,eureka server將會移除該例項。但是當網路分割槽故障發生時,微服務與eureka server之間無法正常通訊,而微服務本身是正常執行的,此時不應該移除這個微服務,所以引入了自我保護機制。
官方對於自我保護機制的定義:
自我保護模式正是一種針對網路異常波動的安全保護措施,使用自我保護模式能使eureka集群更加的健壯、穩定的執行。自我保護機制的工作機制是:如果在15分鐘內超過85%的客戶端節點都沒有正常的心跳,那麼eureka就認為客戶端與註冊中心出現了網路故障,eureka server自動進入自我保護機制,此時會出現以下幾種情況:
eureka server不再從註冊列表中移除因為長時間沒收到心跳而應該過期的服務。
eureka server仍然能夠接受新服務的註冊和查詢請求,但是不會被同步到其它節點上,保證當前節點依然可用。
當網路穩定時,當前eureka server新的註冊資訊會被同步到其它節點中。
因此eureka server可以很好的應對因網路故障導致部分節點失聯的情況,而不會像zk那樣如果有一半不可用的情況會導致整個集群不可用而變成癱瘓。
eureka自我保護機制,通過配置eureka.server.enable-self-preservation
來true
開啟/false
禁用自我保護機制,預設開啟狀態,建議生產環境開啟此配置。
開發環境中如果要實現服務失效能自動移除,只需要修改以下配置。
1、 註冊中心關閉自我保護機制,修改檢查失效服務的時間。
eureka:
server:
enable-self-preservation: false
eviction-interval-timer-in-ms: 3000
2、 微服務修改減短服務心跳的時間。
# 預設90秒
lease-expiration-duration-in-seconds: 10
# 預設30秒
lease-renewal-interval-in-seconds: 3
以上配置建議在生產環境使用預設的時間配置。
Spring Cloud Eureka自我保護機制
eureka的自我保護機制 首先來說下cap理論,關於分布式的架構都會涉及到cap理論,eureka用的ap設計,即高可用以及分割槽容錯性 自我保護機制的工作機制是如果在15分鐘內超過85 的客戶端節點都沒有正常的心跳,那麼eureka就認為客戶端與註冊中心出現了網路故障,eureka server...
Eureka自我保護
為什麼會產生 eureka自我保護機制?為了防止以下情況 eurekaclienti可以正常執行,但是與 eurekaserver網路不通情況下,eurekaserver立刻將 eurekaclient服務剔除。如果進入了自我保護模式就不會立刻刪除服務。什麼是自我保護模式?這裡只修改7001和800...
Eureka自我保護
什麼是自我保護模式?預設情況下,如果eurekaserver在一定時間內沒有接收到某個微服務例項的心跳,eurekaserver將會登出該例項 預設90秒 但是當網路分割槽故障發生時,微服務與eurekaserver之間無法正常通訊,以上行為可能變得非常危險了 因為微服務本身其實是健康的,此時本不應...