# micro-server-region **Repository Path**: doshengl/micro-server-region ## Basic Information - **Project Name**: micro-server-region - **Description**: spring cloud 中的region和zone的使用 - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1 - **Created**: 2020-03-02 - **Last Updated**: 2020-12-28 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Spring cloud中的region和zone的使用 ## 1.单元化部署思路 多机房情况下,部署spring Cloud服务,我们希望一个机房内的服务优先调用同一个机房内的服务 当同一个机房的服务不可用的时候,再去调用其它机房的服务,以达到减少延时的作用。 ## 2.服务注册的配置文件 ```aidl eureka: client: prefer-same-zone-eureka: true #地区 region: bj availability-zones: bj: zone-1,zone-2 service-url: zone-1: http://localhost:8080/eureka/ zone-2: http://localhost:8081/eureka/ ``` 当一个服务(作为一个eureka client)向注册中心(eureka server)注册的时候,会根据eureka.client下的配置来进行注册。这里我们主要关心有多个注册中心的情况下,服务会注册到哪个注册中心,并且和哪个注册中心来维持心跳检测。注册中心选择逻辑: ### 2.1 prefer-same-zone-eureka为false 按照service-url下的 list取第一个注册中心来注册,并和其维持心跳检测。不会再向list内的其它的注册中心注册和维持心跳。 只有在第一个注册失败的情况下,才会依次向其它的注册中心注册,总共重试3次,如果3个service-url都没有注册成功,则注册失败。每隔一个心跳时间,会再次尝试。 ### 2.2 如果prefer-same-zone-eureka为true 先通过region取availability-zones内的第一个zone,然后通过这个zone取service-url下的list,并向list内的第一个注册中心进行注册和维持心跳,不会再向list内的其它的注册中心注册和维持心跳。 只有在第一个注册失败的情况下,才会依次向其它的注册中心注册,总共重试3次,如果3个service-url都没有注册成功,则注册失败。每隔一个心跳时间,会再次尝试。 所以说,为了保证服务注册到同一个zone的注册中心,一定要注意availability-zones的顺序,必须把同一zone写在前面 ## 3.服务调用的配置文件 ```aidl eureka: instance: metadata-map: zone: zone-1 ``` 服务消费者和服务提供者分别属于哪个zone,均是通过eureka.instance.metadata-map.zone来判定的。服务消费者会先通过ribbon去注册中心拉取一份服务提供者的列表 然后通过eureka.instance.metadata-map.zone指定的zone进行过滤,过滤之后如果同一个zone内的服务提供者有多个实例,则会轮流调用 只有在同一个zone内的所有服务提供者都不可用时,才会调用其它zone内的服务提供者。