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

Spring?Cloud?Eureka:?指定Zone方式

 更新時間:2022年03月04日 09:04:20   作者:司青  
這篇文章主要介紹了Spring?Cloud?Eureka:?指定Zone方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Eureka如何指定Zone

有坑。

先說結(jié)論:如果想給當前服務指定屬于哪個zone, 使用

eureka.instance.metadata-map.zone=myzone

屬性是無效的,而應該使用:

eureka.client.availabilityZones.beijing=myzone # beijing是region

同時指定region:

eureka.client.region=beijing

至于原因,可以在EurekaClientConfigBean的源碼中找到:

@Override
? ? public String[] getAvailabilityZones(String region) {
? ? ? ? String value = this.availabilityZones.get(region);
? ? ? ? if (value == null) {
? ? ? ? ? ? value = DEFAULT_ZONE;
? ? ? ? }
? ? ? ? return value.split(",");
? ? }

也就是說在判斷當前服務屬于哪個zone時,先從availabilityZone這個Map中查找,查找用的key是region名。

如果找不到,就使用默認值,即我們熟知的defaultZone。

Eureka中的region和Zone

像亞馬遜這種大型的跨境電商平臺,會有很多個機房。這時如果上線一個服務的話,我們希望一個機房內(nèi)的服務優(yōu)先調(diào)用同一個機房內(nèi)的服務,當同一個機房的服務不可用的時候,再去調(diào)用其它機房的服務,以達到減少延時的作用。

于是亞馬遜的 AWS 提供了 region 和 zone 兩個概念

概念

  • region:可以簡單理解為地理上的分區(qū)。比如亞洲地區(qū),或者華北地區(qū),再或者北京地區(qū)等等,沒有具體大小的限制,根據(jù)項目具體的情況,可以自行劃分region。
  • zone:可以簡單理解為 region 內(nèi)的具體機房,比如說 region 劃分為華北地區(qū),然后華北地區(qū)有兩個機房,就可以在此 region 之下劃分出 zone1、zone2 兩個 zone

eureka 也借用了 region 和 zone 的概念

分區(qū)服務架構(gòu)圖

如圖所示,有一個 region:華北地區(qū),下面有兩個機房,機房A 和機房B

每個機房內(nèi)有一個 Eureka Server 集群 和兩個服務提供者 ServiceA 和 ServerB

現(xiàn)在假設 serverA 需要調(diào)用 ServerB 服務,按照就近原則,serverA 會優(yōu)先調(diào)用同一個 zone 內(nèi)的 ServiceB,當 ServiceB 不可用時,才會去調(diào)用另一個 zone 內(nèi)的 ServiceB

Eureka中Regin和 Zone的相關(guān)配置

  • 服務注冊:要保證服務注冊到同一個zone內(nèi)的注冊中心,因為如果注冊到別zone的注冊中心的話,網(wǎng)絡延時比較大,心跳檢測很可能出問題。
  • 服務調(diào)用:要保證優(yōu)先調(diào)用同一個zone內(nèi)的服務,只有在同一個zone內(nèi)的服務不可用時,才去調(diào)用別zone的服務。

服務注冊相關(guān)

eureka:
  client:
    # 盡量向同一區(qū)域的 eureka 注冊,默認為true
    prefer-same-zone-eureka: true
    #地區(qū)
    region: huabei
    availability-zones:
      huabei: zone-1,zone-2
    service-url:
      zone-1: http://localhost:30000/eureka/
      zone-2: http://localhost:30001/eureka/

當存在多個注冊中心時,選擇邏輯為

  • 如果 prefer-same-zone-eureka 為 false,按照 service-url 下的 list 取第一個注冊中心來注冊,并和其維持心跳檢測,不再向list內(nèi)的其它的注冊中心注冊和維持心跳。只有在第一個注冊失敗的情況下,才會依次向其它的注冊中心注冊,總共重試3次,如果3個service-url都沒有注冊成功,則注冊失敗。注冊失敗后每隔一個心跳時間,會再次嘗試。
  • 如果 prefer-same-zone-eureka 為true,先通過 region 取 availability-zones 內(nèi)的第一個zone,然后通過這個zone取 service-url 下的list,并向list內(nèi)的第一個注冊中心進行注冊和維持心跳,不再向list內(nèi)的其它的注冊中心注冊和維持心跳。只有在第一個注冊失敗的情況下,才會依次向其它的注冊中心注冊,總共重試3次,如果3個service-url都沒有注冊成功,則注冊失敗。注冊失敗后每隔一個心跳時間,會再次嘗試。

為了保證服務注冊到同一個 zone 的注冊中心,一定要注意 availability-zones 的順序,必須把同一 zone 寫在最前面

服務調(diào)用

eureka:
  instance:
    # 服務和注冊中心的心跳間隔時間,默認為30s
    lease-renewal-interval-in-seconds: 30
    # 服務和注冊中心的心跳超時時間,默認為90s
    lease-expiration-duration-in-seconds: 90
    metadata-map:
      # 當前服務所屬的 zone
      zone: zone1
 

服務消費者和服務提供者分別屬于哪個zone,均是通過 eureka.instance.metadata-map.zone 來判定的。

服務消費者會先通過 ribbon 去注冊中心拉取一份服務提供者的列表,然后通過 eureka.instance.metadata-map.zone 指定的 zone 進行過濾,過濾之后如果同一個 zone 內(nèi)的服務提供者有多個實例,則會輪流調(diào)用。

只有在同一個 zone 內(nèi)的所有服務提供者都不可用時,才會調(diào)用其它zone內(nèi)的服務提供者。

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

相關(guān)文章

  • 解決java轉(zhuǎn)義json出現(xiàn)\u0000 等亂碼的問題

    解決java轉(zhuǎn)義json出現(xiàn)\u0000 等亂碼的問題

    這篇文章主要介紹了解決java轉(zhuǎn)義json出現(xiàn)\u0000 等亂碼的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • 通過Feign進行調(diào)用@FeignClient?找不到的解決方案

    通過Feign進行調(diào)用@FeignClient?找不到的解決方案

    這篇文章主要介紹了通過Feign進行調(diào)用@FeignClient?找不到的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 深入了解Java I/O 之File類

    深入了解Java I/O 之File類

    這篇文章主要介紹了Java I/O深入學習之File和RandomAccessFile, I/O系統(tǒng)即輸入/輸出系統(tǒng),對于一門程序語言來說,創(chuàng)建一個好的輸入/輸出系統(tǒng)并非易事。需要的朋友可以參考下
    2021-08-08
  • spring?boot前后端交互之數(shù)據(jù)格式轉(zhuǎn)換問題

    spring?boot前后端交互之數(shù)據(jù)格式轉(zhuǎn)換問題

    這篇文章主要介紹了spring?boot前后端交互之數(shù)據(jù)格式轉(zhuǎn)換,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • 一文帶你深入了解Java的數(shù)據(jù)結(jié)構(gòu)

    一文帶你深入了解Java的數(shù)據(jù)結(jié)構(gòu)

    Java工具包提供了強大的數(shù)據(jù)結(jié)構(gòu)。這篇文章主要為大家詳細介紹了Java數(shù)據(jù)結(jié)構(gòu)中常用的幾種接口和類,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-05-05
  • java list中包含某個字符串的兩種方法實現(xiàn)

    java list中包含某個字符串的兩種方法實現(xiàn)

    在Java開發(fā)中,經(jīng)常需要判斷一個List中是否包含特定的字符串,包括使用contains()方法和循環(huán)遍歷判斷,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • Java多線程循環(huán)柵欄CyclicBarrier正確使用方法

    Java多線程循環(huán)柵欄CyclicBarrier正確使用方法

    這篇文章主要介紹了Java多線程循環(huán)柵欄CyclicBarrier正確使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • Spring概述和快速構(gòu)建的方式

    Spring概述和快速構(gòu)建的方式

    Spring是一個輕量級的控制反轉(zhuǎn)(IoC)和面向切面(AOP)的容器(框架),Spring使用基本的JavaBean來完成以前只可能由EJB完成的事情,本文給大家介紹spring概述和快速構(gòu)建方式,一起看看吧
    2021-06-06
  • 淺談java獲取UUID與UUID的校驗

    淺談java獲取UUID與UUID的校驗

    這篇文章主要介紹了java獲取UUID與UUID的校驗,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • 一篇文章帶你了解Spring?AOP?的注解

    一篇文章帶你了解Spring?AOP?的注解

    這篇文章主要為大家介紹了vue組件通信的幾種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01

最新評論