Springcloud中的region和zone的使用實例
一、背景
用戶量比較大或者用戶地理位置分布范圍很廣的項目,一般都會有多個機(jī)房。這個時候如果上線springCloud服務(wù)的話,我們希望一個機(jī)房內(nèi)的服務(wù)優(yōu)先調(diào)用同一個機(jī)房內(nèi)的服務(wù)
,當(dāng)同一個機(jī)房的服務(wù)不可用的時候,再去調(diào)用其它機(jī)房的服務(wù),以達(dá)到減少延時的作用。
二、概念
eureka提供了region和zone兩個概念來進(jìn)行分區(qū),這兩個概念均來自于亞馬遜的AWS:
(1)region:可以簡單理解為地理上的分區(qū),比如亞洲地區(qū),或者華北地區(qū),再或者北京等等,沒有具體大小的限制。根據(jù)項目具體的情況,可以自行合理劃分region。
(2)zone:可以簡單理解為region內(nèi)的具體機(jī)房,比如說region劃分為北京,然后北京有兩個機(jī)房,就可以在此region之下劃分出zone1,zone2兩個zone。
三、分區(qū)服務(wù)的部署架構(gòu)圖
如上圖所示,有一個region:beijing,下面有zone-1和zone-2兩個分區(qū),每個分區(qū)內(nèi)有一個注冊中心Eureka Server和一個服務(wù)提供者Service。我們在zone-1內(nèi)創(chuàng)建一個
Consumer-1服務(wù)消費者的話,其會優(yōu)先調(diào)用同一個zone內(nèi)的Service-1,當(dāng)Service-1不可用時,才會去調(diào)用zone-2內(nèi)的Service-2。
四、例子
(1)Eureka Server-1:
spring: application: name: Server-1 server: port: 30000 eureka: instance: prefer-ip-address: true status-page-url-path: /actuator/info health-check-url-path: /actuator/health hostname: localhost client: register-with-eureka: true fetch-registry: true prefer-same-zone-eureka: true #地區(qū) region: beijing availability-zones: beijing: zone-1,zone-2 service-url: zone-1: http://localhost:30000/eureka/ zone-2: http://localhost:30001/eureka/
(2)Eureka Server-2:
spring: application: name: Server-2 server: port: 30001 eureka: instance: prefer-ip-address: true status-page-url-path: /actuator/info health-check-url-path: /actuator/health hostname: localhost client: register-with-eureka: true fetch-registry: true prefer-same-zone-eureka: true #地區(qū) region: beijing availability-zones: beijing: zone-2,zone-1 service-url: zone-1: http://localhost:30000/eureka/ zone-2: http://localhost:30001/eureka/
(3)Service1
測試代碼
@RestController public class HiController { @Value("${zone.name}") private String zoneName; @RequestMapping(value = "/hi", method = RequestMethod.GET) public String hi() { return zoneName; } }
配置文件
spring: application: name: service server: port: 30010 eureka: instance: prefer-ip-address: true status-page-url-path: /actuator/info health-check-url-path: /actuator/health metadata-map: zone: zone-1 client: register-with-eureka: true fetch-registry: true prefer-same-zone-eureka: true #地區(qū) region: beijing availability-zones: beijing: zone-1,zone-2 service-url: zone-1: http://localhost:30000/eureka/ zone-2: http://localhost:30001/eureka/
(4)Service2
spring: application: name: service server: port: 30011 eureka: instance: prefer-ip-address: true status-page-url-path: /actuator/info health-check-url-path: /actuator/health metadata-map: zone: zone-2 client: register-with-eureka: true fetch-registry: true prefer-same-zone-eureka: true #地區(qū) region: beijing availability-zones: beijing: zone-2,zone-1 service-url: zone-1: http://localhost:30000/eureka/ zone-2: http://localhost:30001/eureka/
zone.name: zone-2
(5)Consumer-1
測試代碼
@RestController public class HiController { @Autowired private RestTemplate restTemplate; @RequestMapping(value="/consumer") public String hi() { return restTemplate.getForObject("http://service/hi", String.class); } }
配置文件
spring: application: name: consumer server: port: 30030 eureka: instance: prefer-ip-address: true status-page-url-path: /actuator/info health-check-url-path: /actuator/health metadata-map: zone: zone-1 client: register-with-eureka: true fetch-registry: true prefer-same-zone-eureka: true #地區(qū) region: beijing availability-zones: beijing: zone-1,zone-2 service-url: zone-1: http://localhost:30000/eureka/ zone-2: http://localhost:30001/eureka/
五、配置文件詳解
整個分區(qū)分為兩步:
(1)服務(wù)注冊:要保證服務(wù)注冊到同一個zone內(nèi)的注冊中心,因為如果注冊到別zone的注冊中心的話,網(wǎng)絡(luò)延時比較大,心跳檢測很可能出問題。
(2)服務(wù)調(diào)用:要保證優(yōu)先調(diào)用同一個zone內(nèi)的服務(wù),只有在同一個zone內(nèi)的服務(wù)不可用時,才去調(diào)用別zone的服務(wù)。
1、服務(wù)注冊的配置文件
eureka: client: prefer-same-zone-eureka: true #地區(qū) region: beijing availability-zones: beijing: zone-1,zone-2 service-url: zone-1: http://localhost:30000/eureka/ zone-2: http://localhost:30001/eureka/
當(dāng)一個服務(wù)(作為一個eureka client)向注冊中心(eureka server)注冊的時候,會根據(jù)eureka.client下的配置來進(jìn)行注冊。這里我們主要關(guān)心有多個注冊中心的情況下,服務(wù)會注
冊到哪個注冊中心,并且和哪個注冊中心來維持心跳檢測。注冊中心選擇邏輯:
(1)如果prefer-same-zone-eureka為false,按照service-url下的 list取第一個注冊中心來注冊,并和其維持心跳檢測。不會再向list內(nèi)的其它的注冊中心注冊和維持心跳。只有在第
一個注冊失敗的情況下,才會依次向其它的注冊中心注冊,總共重試3次,如果3個service-url都沒有注冊成功,則注冊失敗。每隔一個心跳時間,會再次嘗試。
(2)如果prefer-same-zone-eureka為true,先通過region取availability-zones內(nèi)的第一個zone,然后通過這個zone取service-url下的list,并向list內(nèi)的第一個注冊中心進(jìn)行注冊
和維持心跳,不會再向list內(nèi)的其它的注冊中心注冊和維持心跳。只有在第一個注冊失敗的情況下,才會依次向其它的注冊中心注冊,總共重試3次,如果3個service-url都沒有注冊成
功,則注冊失敗。每隔一個心跳時間,會再次嘗試。
所以說,為了保證服務(wù)注冊到同一個zone的注冊中心,一定要注意availability-zones的順序,必須把同一zone寫在前面
2、服務(wù)調(diào)用的配置文件
eureka: instance: metadata-map: zone: zone-1
服務(wù)消費者和服務(wù)提供者分別屬于哪個zone,均是通過eureka.instance.metadata-map.zone來判定的。服務(wù)消費者會先通過ribbon去注冊中心拉取一份服務(wù)提供者的列表,然后通
過eureka.instance.metadata-map.zone指定的zone進(jìn)行過濾,過濾之后如果同一個zone內(nèi)的服務(wù)提供者有多個實例,則會輪流調(diào)用。只有在同一個zone內(nèi)的所有服務(wù)提供者都不
可用時,才會調(diào)用其它zone內(nèi)的服務(wù)提供者。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解SpringMVC?HandlerInterceptor攔截器的使用與參數(shù)
本文主要介紹了詳解SpringMVC?HandlerInterceptor攔截器的使用與參數(shù),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01SpringBoot實現(xiàn)多個ApplicationRunner時部分接口未執(zhí)行問題
這篇文章主要介紹了SpringBoot實現(xiàn)多個ApplicationRunner時部分接口未執(zhí)行問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05Java 實現(xiàn)漢字轉(zhuǎn)換為拼音的實例
這篇文章主要介紹了Java 實現(xiàn)漢字轉(zhuǎn)換為拼音的實例的相關(guān)資料,需要的朋友可以參考下2016-12-12Java replaceAll()方法報錯Illegal group reference的解決辦法
這篇文章主要給大家介紹了關(guān)于Java replaceAll()方法報錯Illegal group reference的解決辦法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09intelliJ idea 2023 配置Tomcat 8圖文教程
這篇文章主要介紹了intelliJ idea 2023 配置Tomcat 8教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06