溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何分析Eureka集群和自我保護機制

發(fā)布時間:2021-12-02 15:11:33 來源:億速云 閱讀:144 作者:柒染 欄目:大數(shù)據(jù)

這篇文章將為大家詳細講解有關(guān)如何分析Eureka集群和自我保護機制,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

Eureka 自我保護機制

進入自我保護機制的標(biāo)志【重點】

在使用Eureka的過程中,有時候會在Eureka服務(wù)端的頁面上看到如下的內(nèi)容:

如何分析Eureka集群和自我保護機制  

在監(jiān)控頁面上會看到一行紅字兒,這些紅字兒什么意思呢?代表著Eureka注冊中心進入了自我保護機制。

 

什么是自我保護機制【重點】

默認(rèn)情況下,如果Eureka Server在一定時間內(nèi)沒有接受到服務(wù)實例的心跳,Eureka將會注銷該實例(默認(rèn)90秒).但是當(dāng)網(wǎng)絡(luò)分區(qū)發(fā)生故障時,微服務(wù)客戶端和Eureka Server 無法正常通信。以上行為可能變得特別危險了,因為微服務(wù)本身是健康的,此時不能注銷該服務(wù)實例。

Eureka通過自我保護機制來解決這個問題,當(dāng)Eureka Server在短時間丟失過多的服務(wù)實例(可能發(fā)生了網(wǎng)絡(luò)分區(qū)的故障),那么Eureka Server進入自我保護模式,一旦進入此模式,Eureka Server將會保護服務(wù)注冊表中的信息,不再刪除服務(wù)注冊表中的數(shù)據(jù)(也就是不再注銷任何的服務(wù)實例),當(dāng)網(wǎng)絡(luò)故障恢復(fù)后,Eureka Server會自動退出自我保護模式。

綜上,自我保護模式是一種應(yīng)對網(wǎng)絡(luò)故障的安全保護措施,它的架構(gòu)哲學(xué)是寧可同時保留所有的微服務(wù),也不盲目注銷任何健康的微服務(wù),使用自我保護模式可以讓Eureka,更加健壯,穩(wěn)定。

一句話:大面積出現(xiàn)客戶端失聯(lián)的時候,Eureka 注冊中心進入自我保護模式,不注銷任何實例

 

自我保護機制的配置

在Eureka Server中配置關(guān)閉自我保護機制

#關(guān)閉自我保護機制  默認(rèn)開啟
eureka.server.enable-self-preservation=false
 

如果想及時剔除失效的eureka服務(wù)除了關(guān)閉自我保護機制外,可以調(diào)低eureka的心跳值

eureka-server服務(wù)端
配置文件中我們添加如下配置

#關(guān)閉保護機制,以確保注冊中心將不可用的實例正確剔除
eureka.server.enable-self-preservation=false
#(代表是5秒,單位是毫秒,清理失效服務(wù)的間隔 )
eureka.server.eviction-interval-timer-in-ms=5000

 
客戶端
配置文件中我們添加如下配置

# 心跳檢測檢測與續(xù)約時間
# 測試時將值設(shè)置設(shè)置小些,保證服務(wù)關(guān)閉后注冊中心能及時踢出服務(wù)
# 配置說明
#  lease-renewal-interval-in-seconds 每間隔10s,向服務(wù)端發(fā)送一次心跳,證明自己依然”存活“
#  lease-expiration-duration-in-seconds  告訴服務(wù)端,如果我20s之內(nèi)沒有給你發(fā)心跳,就代表我“死”了,將我踢出掉。
eureka.instance.lease-renewal-interval-in-seconds=10
eureka.instance.lease-expiration-duration-in-seconds=20
   

注冊中心高可用「注冊中心集群」

注冊中心集群  防止單點故障

Eureka可以通過運行多個實例并互相注冊實現(xiàn)高可用部署,Eureka Server實例會彼此同步信息。

 

創(chuàng)建并配置Eureka集群

Tips:代碼在前上篇教程的基礎(chǔ)上開發(fā),源碼地址:https://gitee.com/bingqilinpeishenme/Java-Tutorials

1.創(chuàng)建第二個Eureka服務(wù)端 eureka-server-8800

如何分析Eureka集群和自我保護機制  

2.修改pom文件

如何分析Eureka集群和自我保護機制  

3.創(chuàng)建并修改啟動類

package com.lby;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

/**
* @author luxiaoyang
* @create 2020-03-30-20:36
*/
@EnableEurekaServer
@SpringBootApplication
public class EurekaServer8800 {
   public static void main(String[] args) {
       SpringApplication.run(EurekaServer8800.class,args);
   }
}

 

4.寫配置文件

如何分析Eureka集群和自我保護機制  

5.修改注冊中心eureka-server-8801的配置文件

注冊中心之間的基本邏輯是:互相注冊

如何分析Eureka集群和自我保護機制  

此時我們就擁有了一個Eureka注冊中心的集群

6.修改所有客戶端的配置,客戶端需要向 注冊中心集群注冊 所以需要配置所有注冊中心的地址

如何分析Eureka集群和自我保護機制  
 

演示注冊中心集群的效果

1.啟動所有的注冊中心和客戶端

2.查看Eureka注冊中心管理頁面

查看注冊中心 8800 的管理頁面,可以看到客戶端可以正常注冊

如何分析Eureka集群和自我保護機制  

查看注冊中心 8801 的管理頁面,可以看到客戶端也可以正常注冊

如何分析Eureka集群和自我保護機制  

3.關(guān)閉一個注冊中心8800,注冊中心8801不受任何影響,整個微服務(wù)的集群也不受任何影響,客戶端可以正常注冊

關(guān)于如何分析Eureka集群和自我保護機制就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI