Springcloud中的region和zone的使用实例

 更新时间:2019年10月16日 11:23:18   作者:巡山小妖N  
这篇文章主要介绍了Springcloud中的region和zone的使用实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

一、背景

用户量比较大或者用户地理位置分布范围很广的项目,一般都会有多个机房。这个时候如果上线springCloud服务的话,我们希望一个机房内的服务优先调用同一个机房内的服务

,当同一个机房的服务不可用的时候,再去调用其它机房的服务,以达到减少延时的作用。

二、概念

eureka提供了region和zone两个概念来进行分区,这两个概念均来自于亚马逊的AWS:

(1)region:可以简单理解为地理上的分区,比如亚洲地区,或者华北地区,再或者北京等等,没有具体大小的限制。根据项目具体的情况,可以自行合理划分region。

(2)zone:可以简单理解为region内的具体机房,比如说region划分为北京,然后北京有两个机房,就可以在此region之下划分出zone1,zone2两个zone。

三、分区服务的部署架构图

如上图所示,有一个region:beijing,下面有zone-1和zone-2两个分区,每个分区内有一个注册中心Eureka Server和一个服务提供者Service。我们在zone-1内创建一个

Consumer-1服务消费者的话,其会优先调用同一个zone内的Service-1,当Service-1不可用时,才会去调用zone-2内的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
  #地区
  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
  #地区
  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
  #地区
  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
  #地区
  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
  #地区
  region: beijing
  availability-zones:
   beijing: zone-1,zone-2
  service-url:
   zone-1: http://localhost:30000/eureka/
   zone-2: http://localhost:30001/eureka/

五、配置文件详解

整个分区分为两步:

(1)服务注册:要保证服务注册到同一个zone内的注册中心,因为如果注册到别zone的注册中心的话,网络延时比较大,心跳检测很可能出问题。

(2)服务调用:要保证优先调用同一个zone内的服务,只有在同一个zone内的服务不可用时,才去调用别zone的服务。

1、服务注册的配置文件

eureka:
 client:
  prefer-same-zone-eureka: true
  #地区
  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)注册的时候,会根据eureka.client下的配置来进行注册。这里我们主要关心有多个注册中心的情况下,服务会注

册到哪个注册中心,并且和哪个注册中心来维持心跳检测。注册中心选择逻辑:

(1)如果prefer-same-zone-eureka为false,按照service-url下的 list取第一个注册中心来注册,并和其维持心跳检测。不会再向list内的其它的注册中心注册和维持心跳。只有在第

一个注册失败的情况下,才会依次向其它的注册中心注册,总共重试3次,如果3个service-url都没有注册成功,则注册失败。每隔一个心跳时间,会再次尝试。

(2)如果prefer-same-zone-eureka为true,先通过region取availability-zones内的第一个zone,然后通过这个zone取service-url下的list,并向list内的第一个注册中心进行注册

和维持心跳,不会再向list内的其它的注册中心注册和维持心跳。只有在第一个注册失败的情况下,才会依次向其它的注册中心注册,总共重试3次,如果3个service-url都没有注册成

功,则注册失败。每隔一个心跳时间,会再次尝试。

所以说,为了保证服务注册到同一个zone的注册中心,一定要注意availability-zones的顺序,必须把同一zone写在前面

2、服务调用的配置文件

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

服务消费者和服务提供者分别属于哪个zone,均是通过eureka.instance.metadata-map.zone来判定的。服务消费者会先通过ribbon去注册中心拉取一份服务提供者的列表,然后通

过eureka.instance.metadata-map.zone指定的zone进行过滤,过滤之后如果同一个zone内的服务提供者有多个实例,则会轮流调用。只有在同一个zone内的所有服务提供者都不

可用时,才会调用其它zone内的服务提供者。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Java基础知识精通各种运算符

    Java基础知识精通各种运算符

    计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,Java也提供了一套丰富的运算符来操纵变量,本篇对大家的学习或工作具有一定的价值,需要的朋友可以参考下
    2022-04-04
  • idea如何配置springboot热部署

    idea如何配置springboot热部署

    这篇文章主要介绍了idea如何配置springboot热部署问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Java 照片对比功能的实现

    Java 照片对比功能的实现

    这篇文章主要介绍了Java 照片比对功能实现类的示例代码,帮助大家更好的理解和学习Java,感兴趣的朋友可以了解下
    2020-12-12
  • 详解SpringMVC HandlerInterceptor拦截器的使用与参数

    详解SpringMVC HandlerInterceptor拦截器的使用与参数

    本文主要介绍了详解SpringMVC HandlerInterceptor拦截器的使用与参数,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • java实现接口的典型案例

    java实现接口的典型案例

    下面小编就为大家带来一篇java实现接口的典型案例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • 详解Java8 新特性之日期API

    详解Java8 新特性之日期API

    Java 8 在包java.time下包含了一组全新的时间日期API。下面通过示例给大家讲解java8 新特征日期api的相关知识,感兴趣的朋友一起看看吧
    2017-07-07
  • SpringBoot实现多个ApplicationRunner时部分接口未执行问题

    SpringBoot实现多个ApplicationRunner时部分接口未执行问题

    这篇文章主要介绍了SpringBoot实现多个ApplicationRunner时部分接口未执行问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • Java 实现汉字转换为拼音的实例

    Java 实现汉字转换为拼音的实例

    这篇文章主要介绍了Java 实现汉字转换为拼音的实例的相关资料,需要的朋友可以参考下
    2016-12-12
  • Java replaceAll()方法报错Illegal group reference的解决办法

    Java replaceAll()方法报错Illegal group reference的解决办法

    这篇文章主要给大家介绍了关于Java replaceAll()方法报错Illegal group reference的解决办法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • intelliJ idea 2023 配置Tomcat 8图文教程

    intelliJ idea 2023 配置Tomcat 8图文教程

    这篇文章主要介绍了intelliJ idea 2023 配置Tomcat 8教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06

最新评论