用户量比较大或者用户地理位置分布范围很广的项目,一般都会有多个机房。这个时候如果上线springCloud服务的话,我们希望一个机房内的服务优先调用同一个机房内的服务,当同一个机房的服务不可用的时候,再去调用其它机房的服务,以达到减少延时的作用。

概念

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

  • region:可以简单理解为地理上的分区,比如亚洲地区,或者华北地区,再或者北京等等,没有具体大小的限制。根据项目具体的情况,可以自行合理划分region。
  • 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: truestatus-page-url-path: /actuator/infohealth-check-url-path: /actuator/healthhostname: localhostclient:register-with-eureka: truefetch-registry: trueprefer-same-zone-eureka: true#地区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#地区region: beijingavailability-zones:beijing: zone-2,zone-1service-url:zone-1: http://localhost:30000/eureka/zone-2: http://localhost:30001/eureka/
  3. Service-1:

    测试代码:

    @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#地区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. Service-2:

    spring:application:name: service
    server:port: 30011
    eureka:instance:prefer-ip-address: truestatus-page-url-path: /actuator/infohealth-check-url-path: /actuator/healthmetadata-map:zone: zone-2client:register-with-eureka: truefetch-registry: trueprefer-same-zone-eureka: true#地区region: beijingavailability-zones:beijing: zone-2,zone-1service-url:zone-1: http://localhost:30000/eureka/zone-2: http://localhost:30001/eureka/zone.name: zone-2
  5. Consumer-1:

    调用服务代码:

    @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#地区region: beijingavailability-zones:beijing: zone-1,zone-2service-url:zone-1: http://localhost:30000/eureka/zone-2: http://localhost:30001/eureka/

效果演示

可以看到Consumer-1优先调用的是同一个zone-1的Service-1,这个时候,无论怎么刷新,调用多少次,都只会调用Service-1,不会调用Service-2.

当我们把Service-1服务停掉,再调用的话:

才会调用zone-2分区下的Service-2。

配置文件讲解

整个分区分为两步:

  1. 服务注册:要保证服务注册到同一个zone内的注册中心,因为如果注册到别zone的注册中心的话,网络延时比较大,心跳检测很可能出问题。
  2. 服务调用:要保证优先调用同一个zone内的服务,只有在同一个zone内的服务不可用时,才去调用别zone的服务。

1. 服务注册的配置文件

eureka:client:prefer-same-zone-eureka: true#地区region: beijingavailability-zones:beijing: zone-1,zone-2service-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内的服务提供者。

扩展

eureka.instance.lease-renewal-interval-in-seconds: 30

服务和注册中心的心跳间隔时间,默认为30s

eureka.instance.lease-expiration-duration-in-seconds: 90

服务和注册中心的心跳超时时间,默认为90s

也就是说,当一个服务异常down掉后,90s之后注册中心才会知道这个服务不可用了。在此期间,依旧会把这个服务当成正常服务。ribbon调用仍会把请求转发到这个服务上。为了避免这段期间出现无法提供服务的情况,要开启ribbon的重试功能,去进行其它服务提供者的重试。

euraka 分区概念相关推荐

  1. Linux学习之CentOS(八)--Linux系统的分区概念

    不知不觉已经记录了8篇Linux学习随笔了,虽然还是漂浮在Linux系统的表面,还有很多很多没有学,但是坚持学下去.坚持写下去就是成功的!!!! 在讲Linux系统分区之前,首先得介绍一下硬盘分区的知 ...

  2. Swap交换分区概念

    Swap交换分区概念 什么是Linux swap space呢?我们先来看看下面两段关于Linux swap space的英文介绍资料: Linux divides its physical RAM ...

  3. linux Swap交换分区概念

    Swap交换分区概念 什么是Linux swap space呢?我们先来看看下面两段关于Linux swap space的英文介绍资料: Linux divides its physical RAM ...

  4. linux分区概念理解,在linux安装中的分区概念(转)

    在linux安装中的分区概念(转)[@more@] 首先我们需要知道,硬盘分区的存在,是由硬盘的物理特性决定的,并不会因为不同的操作系统而有所改变. 请您把一块硬盘想象为一本书--即便您不喜欢读书,您 ...

  5. 数据库分区概念及简单运用

    概念:数据库分区是一种物理数据库设计技术 目的:主要目的是为了在特定SQL操作中减少数据读写的总量以缩短响应时间 分类:分为水平分区(Horizontal Paritioning)和垂直分区(Vert ...

  6. Oracle表分区概念和实战

    YYOracle 11g分区表创建(自动按年.月.日分区) 现在有一张回单表,每天以十万数据的文件形式推送,定时读取文件写入回单数据,而且是只增不该.所以表数据会越来越多,所以使用分区来进行提高查询性 ...

  7. linux分区概念理解,磁盘分区基础和LINUX上硬盘分区设备号解释

    现在就开始讲讲分区,先明确一下概念: 主分区:一块物理硬盘上可以被独立使用的一部分,一个硬盘最多可以有4个主分区. 扩展分区:为了突破一个物理硬盘只能有4个分区的限制,引入了扩展分区.扩展分区和主分区 ...

  8. oracle 分区概念,Oracle 分区的概念

    Oracle 分区的概念 分区是指将巨型的表或索引分割成相对较小的.可独立管理的部分,这些独立的部分称为原来表或索引的分区.分区后的表与未分区的表在执行查询语句或其他DML语句时没有任何区别,一旦进行 ...

  9. 扇区、块、分区概念的梳理

    硬盘最小的存储单位位sector(扇区),sector = 512字节 block(块)= 8 * sector = 4MB: 一个file,至少占用一个inode,至少占用一个block: inod ...

最新文章

  1. HDU6964 I love counting (字典树+莫队)
  2. Android中RecyclerView嵌套RecyclerView或嵌套ListView
  3. Java LocalDate类| 带示例的compareTo()方法
  4. “10%时间”:优点和缺点——敏捷海滩会议上Elizabeth Pope的报告
  5. 深度学习笔记(46) 深度卷积网络学习
  6. 《如何搭建小微企业风控模型》第九节 单变量分析(上)节选
  7. 7号团队-团队任务5:项目总结
  8. 11gR2 集群(CRS/GRID)新功能—— SCAN(Single Client Access Name)
  9. Docker-----Cgroup资源配置详细教程,图文并茂
  10. python制作ico图标_Python 批量 png 转 ico
  11. e900v21e 装第三方_创维e900v21e刷机包
  12. python代码转换成EXE文件之pyinstaller使用教程
  13. 别瞎扯,元宇宙就是没有切实发展?
  14. 华硕Afudos更新bios方法介绍
  15. 12306APP找回密码操作后账户被注销BUG
  16. python中test是什么意思_Python unittest 之一: 什么是单元测试
  17. c语言main必须返回int,C语言 错误:’:: main’必须返回’int’
  18. springboot+elasticsearch+neo4j+vue+activiti数字知识库管理系统
  19. 优思学院|质量大师的那些名言(一)【质量是免费的】
  20. 我多想时光都可以典当,你回来带我赎回过往

热门文章

  1. 【视频点播】阿里云视频点播如何获取视频播放的URL
  2. Linux 版本的百度云盘来了!!!
  3. USB Type C数据线接线方式、工作原理
  4. android 百度坐标 gps,Android中gps定位不返回经纬度的解决方案
  5. 遥测终端机RTU的特点以及应用领域
  6. Java基础知识之封装+继承+多态详解
  7. 给HashMap排序的方法
  8. 基于Python的算术编码的设计与实现
  9. STM32F205ZET引脚控制FM24CL16B问题记录
  10. 学籍信息管理系统 c语言,c语言学籍信息管理系统设计