Spring?Cloud?Eureka:?指定Zone方式
Eureka如何指定Zone
有坑。
先說(shuō)結(jié)論:如果想給當(dāng)前服務(wù)指定屬于哪個(gè)zone, 使用
eureka.instance.metadata-map.zone=myzone
屬性是無(wú)效的,而應(yīng)該使用:
eureka.client.availabilityZones.beijing=myzone # beijing是region
同時(shí)指定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(",");
? ? }也就是說(shuō)在判斷當(dāng)前服務(wù)屬于哪個(gè)zone時(shí),先從availabilityZone這個(gè)Map中查找,查找用的key是region名。
如果找不到,就使用默認(rèn)值,即我們熟知的defaultZone。
Eureka中的region和Zone
像亞馬遜這種大型的跨境電商平臺(tái),會(huì)有很多個(gè)機(jī)房。這時(shí)如果上線一個(gè)服務(wù)的話,我們希望一個(gè)機(jī)房?jī)?nèi)的服務(wù)優(yōu)先調(diào)用同一個(gè)機(jī)房?jī)?nèi)的服務(wù),當(dāng)同一個(gè)機(jī)房的服務(wù)不可用的時(shí)候,再去調(diào)用其它機(jī)房的服務(wù),以達(dá)到減少延時(shí)的作用。
于是亞馬遜的 AWS 提供了 region 和 zone 兩個(gè)概念
概念
region:可以簡(jiǎn)單理解為地理上的分區(qū)。比如亞洲地區(qū),或者華北地區(qū),再或者北京地區(qū)等等,沒有具體大小的限制,根據(jù)項(xiàng)目具體的情況,可以自行劃分region。zone:可以簡(jiǎn)單理解為 region 內(nèi)的具體機(jī)房,比如說(shuō) region 劃分為華北地區(qū),然后華北地區(qū)有兩個(gè)機(jī)房,就可以在此 region 之下劃分出 zone1、zone2 兩個(gè) zone
eureka 也借用了 region 和 zone 的概念
分區(qū)服務(wù)架構(gòu)圖

如圖所示,有一個(gè) region:華北地區(qū),下面有兩個(gè)機(jī)房,機(jī)房A 和機(jī)房B
每個(gè)機(jī)房?jī)?nèi)有一個(gè) Eureka Server 集群 和兩個(gè)服務(wù)提供者 ServiceA 和 ServerB
現(xiàn)在假設(shè) serverA 需要調(diào)用 ServerB 服務(wù),按照就近原則,serverA 會(huì)優(yōu)先調(diào)用同一個(gè) zone 內(nèi)的 ServiceB,當(dāng) ServiceB 不可用時(shí),才會(huì)去調(diào)用另一個(gè) zone 內(nèi)的 ServiceB
Eureka中Regin和 Zone的相關(guān)配置
- 服務(wù)注冊(cè):要保證服務(wù)注冊(cè)到同一個(gè)zone內(nèi)的注冊(cè)中心,因?yàn)槿绻?cè)到別zone的注冊(cè)中心的話,網(wǎng)絡(luò)延時(shí)比較大,心跳檢測(cè)很可能出問(wèn)題。
- 服務(wù)調(diào)用:要保證優(yōu)先調(diào)用同一個(gè)zone內(nèi)的服務(wù),只有在同一個(gè)zone內(nèi)的服務(wù)不可用時(shí),才去調(diào)用別zone的服務(wù)。
服務(wù)注冊(cè)相關(guān)
eureka:
client:
# 盡量向同一區(qū)域的 eureka 注冊(cè),默認(rèn)為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/當(dāng)存在多個(gè)注冊(cè)中心時(shí),選擇邏輯為
- 如果 prefer-same-zone-eureka 為 false,按照 service-url 下的 list 取第一個(gè)注冊(cè)中心來(lái)注冊(cè),并和其維持心跳檢測(cè),不再向list內(nèi)的其它的注冊(cè)中心注冊(cè)和維持心跳。只有在第一個(gè)注冊(cè)失敗的情況下,才會(huì)依次向其它的注冊(cè)中心注冊(cè),總共重試3次,如果3個(gè)service-url都沒有注冊(cè)成功,則注冊(cè)失敗。注冊(cè)失敗后每隔一個(gè)心跳時(shí)間,會(huì)再次嘗試。
- 如果 prefer-same-zone-eureka 為true,先通過(guò) region 取 availability-zones 內(nèi)的第一個(gè)zone,然后通過(guò)這個(gè)zone取 service-url 下的list,并向list內(nèi)的第一個(gè)注冊(cè)中心進(jìn)行注冊(cè)和維持心跳,不再向list內(nèi)的其它的注冊(cè)中心注冊(cè)和維持心跳。只有在第一個(gè)注冊(cè)失敗的情況下,才會(huì)依次向其它的注冊(cè)中心注冊(cè),總共重試3次,如果3個(gè)service-url都沒有注冊(cè)成功,則注冊(cè)失敗。注冊(cè)失敗后每隔一個(gè)心跳時(shí)間,會(huì)再次嘗試。
為了保證服務(wù)注冊(cè)到同一個(gè) zone 的注冊(cè)中心,一定要注意 availability-zones 的順序,必須把同一 zone 寫在最前面
服務(wù)調(diào)用
eureka:
instance:
# 服務(wù)和注冊(cè)中心的心跳間隔時(shí)間,默認(rèn)為30s
lease-renewal-interval-in-seconds: 30
# 服務(wù)和注冊(cè)中心的心跳超時(shí)時(shí)間,默認(rèn)為90s
lease-expiration-duration-in-seconds: 90
metadata-map:
# 當(dāng)前服務(wù)所屬的 zone
zone: zone1
服務(wù)消費(fèi)者和服務(wù)提供者分別屬于哪個(gè)zone,均是通過(guò) eureka.instance.metadata-map.zone 來(lái)判定的。
服務(wù)消費(fèi)者會(huì)先通過(guò) ribbon 去注冊(cè)中心拉取一份服務(wù)提供者的列表,然后通過(guò) eureka.instance.metadata-map.zone 指定的 zone 進(jìn)行過(guò)濾,過(guò)濾之后如果同一個(gè) zone 內(nèi)的服務(wù)提供者有多個(gè)實(shí)例,則會(huì)輪流調(diào)用。
只有在同一個(gè) zone 內(nèi)的所有服務(wù)提供者都不可用時(shí),才會(huì)調(diào)用其它zone內(nèi)的服務(wù)提供者。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決java轉(zhuǎn)義json出現(xiàn)\u0000 等亂碼的問(wèn)題
這篇文章主要介紹了解決java轉(zhuǎn)義json出現(xiàn)\u0000 等亂碼的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03
通過(guò)Feign進(jìn)行調(diào)用@FeignClient?找不到的解決方案
這篇文章主要介紹了通過(guò)Feign進(jìn)行調(diào)用@FeignClient?找不到的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
spring?boot前后端交互之?dāng)?shù)據(jù)格式轉(zhuǎn)換問(wèn)題
這篇文章主要介紹了spring?boot前后端交互之?dāng)?shù)據(jù)格式轉(zhuǎn)換,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01
一文帶你深入了解Java的數(shù)據(jù)結(jié)構(gòu)
Java工具包提供了強(qiáng)大的數(shù)據(jù)結(jié)構(gòu)。這篇文章主要為大家詳細(xì)介紹了Java數(shù)據(jù)結(jié)構(gòu)中常用的幾種接口和類,感興趣的小伙伴可以跟隨小編一起了解一下2023-05-05
java list中包含某個(gè)字符串的兩種方法實(shí)現(xiàn)
在Java開發(fā)中,經(jīng)常需要判斷一個(gè)List中是否包含特定的字符串,包括使用contains()方法和循環(huán)遍歷判斷,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03
Java多線程循環(huán)柵欄CyclicBarrier正確使用方法
這篇文章主要介紹了Java多線程循環(huán)柵欄CyclicBarrier正確使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09

