成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Springcloud中的region和zone的使用實例

一、背景

成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供烏魯木齊企業(yè)網(wǎng)站建設,專注與做網(wǎng)站、網(wǎng)站建設、html5、小程序制作等業(yè)務。10年已為烏魯木齊眾多企業(yè)、政府機構(gòu)等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡公司優(yōu)惠進行中。

用戶量比較大或者用戶地理位置分布范圍很廣的項目,一般都會有多個機房。這個時候如果上線springCloud服務的話,我們希望一個機房內(nèi)的服務優(yōu)先調(diào)用同一個機房內(nèi)的服務

,當同一個機房的服務不可用的時候,再去調(diào)用其它機房的服務,以達到減少延時的作用。

二、概念

eureka提供了region和zone兩個概念來進行分區(qū),這兩個概念均來自于亞馬遜的AWS:

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

(2)zone:可以簡單理解為region內(nèi)的具體機房,比如說region劃分為北京,然后北京有兩個機房,就可以在此region之下劃分出zone1,zone2兩個zone。

三、分區(qū)服務的部署架構(gòu)圖

Springcloud中的region和zone的使用實例

如上圖所示,有一個region:beijing,下面有zone-1和zone-2兩個分區(qū),每個分區(qū)內(nèi)有一個注冊中心Eureka Server和一個服務提供者Service。我們在zone-1內(nèi)創(chuàng)建一個

Consumer-1服務消費者的話,其會優(yōu)先調(diào)用同一個zone內(nèi)的Service-1,當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)服務注冊:要保證服務注冊到同一個zone內(nèi)的注冊中心,因為如果注冊到別zone的注冊中心的話,網(wǎng)絡延時比較大,心跳檢測很可能出問題。

(2)服務調(diào)用:要保證優(yōu)先調(diào)用同一個zone內(nèi)的服務,只有在同一個zone內(nèi)的服務不可用時,才去調(diào)用別zone的服務。

1、服務注冊的配置文件

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/

當一個服務(作為一個eureka client)向注冊中心(eureka server)注冊的時候,會根據(jù)eureka.client下的配置來進行注冊。這里我們主要關心有多個注冊中心的情況下,服務會注

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

(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)的第一個注冊中心進行注冊

和維持心跳,不會再向list內(nèi)的其它的注冊中心注冊和維持心跳。只有在第一個注冊失敗的情況下,才會依次向其它的注冊中心注冊,總共重試3次,如果3個service-url都沒有注冊成

功,則注冊失敗。每隔一個心跳時間,會再次嘗試。

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

2、服務調(diào)用的配置文件

eureka:
 instance:
  metadata-map:
   zone: zone-1

服務消費者和服務提供者分別屬于哪個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)的服務提供者。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

本文名稱:Springcloud中的region和zone的使用實例
網(wǎng)頁路徑:http://jinyejixie.com/article24/ghheje.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃、品牌網(wǎng)站制作、建站公司、搜索引擎優(yōu)化做網(wǎng)站、用戶體驗

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
义乌市| 临高县| 千阳县| 深圳市| 安西县| 黄骅市| 津南区| 泾源县| 工布江达县| 观塘区| 大兴区| 中方县| 鄂尔多斯市| 和平区| 永顺县| 阿拉善盟| 宁阳县| 石柱| 澄迈县| 南皮县| 安徽省| 万山特区| 绩溪县| 湄潭县| 曲沃县| 望江县| 巫溪县| 汉中市| 咸阳市| 定结县| 佛坪县| 广南县| 六枝特区| 黄陵县| 潜江市| 沂南县| 阜南县| 财经| 兴安县| 虹口区| 囊谦县|