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

Springcloud中的region和zone的使用實(shí)例

 更新時(shí)間:2019年10月16日 11:23:18   作者:巡山小妖N  
這篇文章主要介紹了Springcloud中的region和zone的使用實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

一、背景

用戶量比較大或者用戶地理位置分布范圍很廣的項(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è)概念來進(jìn)行分區(qū),這兩個(gè)概念均來自于亞馬遜的AWS:

(1)region:可以簡(jiǎn)單理解為地理上的分區(qū),比如亞洲地區(qū),或者華北地區(qū),再或者北京等等,沒有具體大小的限制。根據(jù)項(xiàng)目具體的情況,可以自行合理劃分region。

(2)zone:可以簡(jiǎn)單理解為region內(nèi)的具體機(jī)房,比如說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: 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

測(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: 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

測(cè)試代碼

@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/

五、配置文件詳解

整個(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: beijing
  availability-zones:
   beijing: zone-1,zone-2
  service-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下的配置來進(jìn)行注冊(cè)。這里我們主要關(guān)心有多個(gè)注冊(cè)中心的情況下,服務(wù)會(huì)注

冊(cè)到哪個(gè)注冊(cè)中心,并且和哪個(gè)注冊(cè)中心來維持心跳檢測(cè)。注冊(cè)中心選擇邏輯:

(1)如果prefer-same-zone-eureka為false,按照service-url下的 list取第一個(gè)注冊(cè)中心來注冊(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ì)再次嘗試。

所以說,為了保證服務(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來判定的。服務(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ù)提供者。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java基礎(chǔ)知識(shí)精通各種運(yùn)算符

    Java基礎(chǔ)知識(shí)精通各種運(yùn)算符

    計(jì)算機(jī)的最基本用途之一就是執(zhí)行數(shù)學(xué)運(yùn)算,作為一門計(jì)算機(jī)語言,Java也提供了一套豐富的運(yùn)算符來操縱變量,本篇對(duì)大家的學(xué)習(xí)或工作具有一定的價(jià)值,需要的朋友可以參考下
    2022-04-04
  • idea如何配置springboot熱部署

    idea如何配置springboot熱部署

    這篇文章主要介紹了idea如何配置springboot熱部署問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Java 照片對(duì)比功能的實(shí)現(xiàn)

    Java 照片對(duì)比功能的實(shí)現(xiàn)

    這篇文章主要介紹了Java 照片比對(duì)功能實(shí)現(xiàn)類的示例代碼,幫助大家更好的理解和學(xué)習(xí)Java,感興趣的朋友可以了解下
    2020-12-12
  • 詳解SpringMVC?HandlerInterceptor攔截器的使用與參數(shù)

    詳解SpringMVC?HandlerInterceptor攔截器的使用與參數(shù)

    本文主要介紹了詳解SpringMVC?HandlerInterceptor攔截器的使用與參數(shù),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • java實(shí)現(xiàn)接口的典型案例

    java實(shí)現(xiàn)接口的典型案例

    下面小編就為大家?guī)硪黄猨ava實(shí)現(xiàn)接口的典型案例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • 詳解Java8 新特性之日期API

    詳解Java8 新特性之日期API

    Java 8 在包java.time下包含了一組全新的時(shí)間日期API。下面通過示例給大家講解java8 新特征日期api的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2017-07-07
  • SpringBoot實(shí)現(xiàn)多個(gè)ApplicationRunner時(shí)部分接口未執(zhí)行問題

    SpringBoot實(shí)現(xiàn)多個(gè)ApplicationRunner時(shí)部分接口未執(zhí)行問題

    這篇文章主要介紹了SpringBoot實(shí)現(xiàn)多個(gè)ApplicationRunner時(shí)部分接口未執(zhí)行問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Java 實(shí)現(xiàn)漢字轉(zhuǎn)換為拼音的實(shí)例

    Java 實(shí)現(xiàn)漢字轉(zhuǎn)換為拼音的實(shí)例

    這篇文章主要介紹了Java 實(shí)現(xiàn)漢字轉(zhuǎn)換為拼音的實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • Java replaceAll()方法報(bào)錯(cuò)Illegal group reference的解決辦法

    Java replaceAll()方法報(bào)錯(cuò)Illegal group reference的解決辦法

    這篇文章主要給大家介紹了關(guān)于Java replaceAll()方法報(bào)錯(cuò)Illegal group reference的解決辦法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • intelliJ idea 2023 配置Tomcat 8圖文教程

    intelliJ idea 2023 配置Tomcat 8圖文教程

    這篇文章主要介紹了intelliJ idea 2023 配置Tomcat 8教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06

最新評(píng)論