javascript
Springcloud中的region和zone的使用
Springcloud中的region和zone的使用
一、背景
用戶量比較大或者用戶地理位置分布范圍很廣的項(xiàng)目,一般都會(huì)有多個(gè)機(jī)房。這個(gè)時(shí)候如果上線springCloud服務(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í)的作用。
二、概念
eureka提供了region和zone兩個(gè)概念來(lái)進(jìn)行分區(qū),這兩個(gè)概念均來(lái)自于亞馬遜的AWS:
(1)region:可以簡(jiǎn)單理解為地理上的分區(qū),比如亞洲地區(qū),或者華北地區(qū),再或者北京等等,沒有具體大小的限制。根據(jù)項(xiàng)目具體的情況,可以自行合理劃分region。
(2)zone:可以簡(jiǎn)單理解為region內(nèi)的具體機(jī)房,比如說(shuō)region劃分為北京,然后北京有兩個(gè)機(jī)房,就可以在此region之下劃分出zone1,zone2兩個(gè)zone。
三、分區(qū)服務(wù)的部署架構(gòu)圖
如上圖所示,有一個(gè)region:beijing,下面有zone-1和zone-2兩個(gè)分區(qū),每個(gè)分區(qū)內(nèi)有一個(gè)注冊(cè)中心Eureka Server和一個(gè)服務(wù)提供者Service。我們?cè)趜one-1內(nèi)創(chuàng)建一個(gè)
Consumer-1服務(wù)消費(fèi)者的話,其會(huì)優(yōu)先調(diào)用同一個(gè)zone內(nèi)的Service-1,當(dāng)Service-1不可用時(shí),才會(huì)去調(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: truestatus-page-url-path: /actuator/infohealth-check-url-path: /actuator/healthhostname: localhostclient:register-with-eureka: truefetch-registry: trueprefer-same-zone-eureka: true#地區(qū)region: beijingavailability-zones:beijing: zone-1,zone-2service-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: truestatus-page-url-path: /actuator/infohealth-check-url-path: /actuator/healthhostname: localhostclient:register-with-eureka: truefetch-registry: trueprefer-same-zone-eureka: true#地區(qū)region: beijingavailability-zones:beijing: zone-2,zone-1service-url:zone-1: http://localhost:30000/eureka/zone-2: http://localhost:30001/eureka/(3)Service1
測(cè)試代碼
@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: truestatus-page-url-path: /actuator/infohealth-check-url-path: /actuator/healthmetadata-map:zone: zone-1client:register-with-eureka: truefetch-registry: trueprefer-same-zone-eureka: true#地區(qū)region: beijingavailability-zones:beijing: zone-1,zone-2service-url:zone-1: http://localhost:30000/eureka/zone-2: http://localhost:30001/eureka/zone.name: zone-1
(4)Service2
zone.name: zone-2
(5)Consumer-1
測(cè)試代碼
@RestController public class HiController {@Autowiredprivate 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: truestatus-page-url-path: /actuator/infohealth-check-url-path: /actuator/healthmetadata-map:zone: zone-1client:register-with-eureka: truefetch-registry: trueprefer-same-zone-eureka: true#地區(qū)region: beijingavailability-zones:beijing: zone-1,zone-2service-url:zone-1: http://localhost:30000/eureka/zone-2: http://localhost:30001/eureka/五、配置文件詳解
整個(gè)分區(qū)分為兩步:
(1)服務(wù)注冊(cè):要保證服務(wù)注冊(cè)到同一個(gè)zone內(nèi)的注冊(cè)中心,因?yàn)槿绻?cè)到別zone的注冊(cè)中心的話,網(wǎng)絡(luò)延時(shí)比較大,心跳檢測(cè)很可能出問題。
(2)服務(wù)調(diào)用:要保證優(yōu)先調(diào)用同一個(gè)zone內(nèi)的服務(wù),只有在同一個(gè)zone內(nèi)的服務(wù)不可用時(shí),才去調(diào)用別zone的服務(wù)。
1、服務(wù)注冊(cè)的配置文件
eureka:client:prefer-same-zone-eureka: true#地區(qū)region: beijingavailability-zones:beijing: zone-1,zone-2service-url:zone-1: http://localhost:30000/eureka/zone-2: http://localhost:30001/eureka/當(dāng)一個(gè)服務(wù)(作為一個(gè)eureka client)向注冊(cè)中心(eureka server)注冊(cè)的時(shí)候,會(huì)根據(jù)eureka.client下的配置來(lái)進(jìn)行注冊(cè)。這里我們主要關(guān)心有多個(gè)注冊(cè)中心的情況下,服務(wù)會(huì)注
冊(cè)到哪個(gè)注冊(cè)中心,并且和哪個(gè)注冊(cè)中心來(lái)維持心跳檢測(cè)。注冊(cè)中心選擇邏輯:
(1)如果prefer-same-zone-eureka為false,按照service-url下的 list取第一個(gè)注冊(cè)中心來(lái)注冊(cè),并和其維持心跳檢測(cè)。不會(huì)再向list內(nèi)的其它的注冊(cè)中心注冊(cè)和維持心跳。只有在第
一個(gè)注冊(cè)失敗的情況下,才會(huì)依次向其它的注冊(cè)中心注冊(cè),總共重試3次,如果3個(gè)service-url都沒有注冊(cè)成功,則注冊(cè)失敗。每隔一個(gè)心跳時(shí)間,會(huì)再次嘗試。
(2)如果prefer-same-zone-eureka為true,先通過region取availability-zones內(nèi)的第一個(gè)zone,然后通過這個(gè)zone取service-url下的list,并向list內(nèi)的第一個(gè)注冊(cè)中心進(jìn)行注冊(cè)
和維持心跳,不會(huì)再向list內(nèi)的其它的注冊(cè)中心注冊(cè)和維持心跳。只有在第一個(gè)注冊(cè)失敗的情況下,才會(huì)依次向其它的注冊(cè)中心注冊(cè),總共重試3次,如果3個(gè)service-url都沒有注冊(cè)成
功,則注冊(cè)失敗。每隔一個(gè)心跳時(shí)間,會(huì)再次嘗試。
所以說(shuō),為了保證服務(wù)注冊(cè)到同一個(gè)zone的注冊(cè)中心,一定要注意availability-zones的順序,必須把同一zone寫在前面
2、服務(wù)調(diào)用的配置文件
eureka:instance:metadata-map:zone: zone-1服務(wù)消費(fèi)者和服務(wù)提供者分別屬于哪個(gè)zone,均是通過eureka.instance.metadata-map.zone來(lái)判定的。服務(wù)消費(fèi)者會(huì)先通過ribbon去注冊(cè)中心拉取一份服務(wù)提供者的列表,然后通
過eureka.instance.metadata-map.zone指定的zone進(jìn)行過濾,過濾之后如果同一個(gè)zone內(nèi)的服務(wù)提供者有多個(gè)實(shí)例,則會(huì)輪流調(diào)用。只有在同一個(gè)zone內(nèi)的所有服務(wù)提供者都不
可用時(shí),才會(huì)調(diào)用其它zone內(nèi)的服務(wù)提供者。
轉(zhuǎn)載自 https://segmentfault.com/a/1190000014107639 https://www.cnblogs.com/junjiang3/p/9061867.html
總結(jié)
以上是生活随笔為你收集整理的Springcloud中的region和zone的使用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SpringCloud-Eureka-服
- 下一篇: Springboot消除switch-c