注册中心(Eureka)高可用部署

1.本文目标

本文主要进行高可用注册中心得服务器搭建。将自己作为服务向其他服注册中心注册自己,形成一组互相注册的服务注册中心,以实现服务清单的互相同步,达到高可用的效果。

2.练习场景

  1. 注册中心配置,注册中心部署,分别部署在两台服务器上。
  2. 多机房注册中心部署,并实现多机房自动转换。

3.注册中心创建和相互注册配置(单机房部署)

3.1 注册中心创建

3.2 相互注册配置

比如有两个eureka服务,分别部署在两台服务器上。

第1个注册中心配置文件application.yml如下:

spring:
    application:
        name: eureka  # 应用名称
server:
    port: 8761  # 应用启动端口
eureka:
    instance:
        hostname: ${spring.cloud.client.ipaddress}
        # 以IP地址注册到服务中心
        prefer-ip-address: true
    client: 
        serviceUrl:
            # Eureka Server地址
            defaultZone: http://server2-IP:8761/eureka/

第2个Eureka 配置文件application.yml如下:

spring:
    application:
        name: eureka  # 应用名称
server:
    port: 8761  # 应用启动端口
eureka:
    instance:
        hostname: ${spring.cloud.client.ipaddress}
        # 以IP地址注册到服务中心
        prefer-ip-address: true
    client: 
        serviceUrl:
            # Eureka Server地址
            defaultZone: http://server1-IP:8761/eureka/

项目中注册中心配置非常简单,分别部署在两台机器上,只须按如下配置每个注册中心并修改defaultZone中的server1-IP 和 server2-IP ,根据实际情况改为服务器具体的IP即可。

配置完上述步骤,两个注册中心服务相互注册,即可启用注册中心的高可用性集群。

3.3 微服务注册到注册中心配置

配置文件中,eureka.client.serviceUrl.defaultZone 增加以上多个Eureka对应的URL:

eureka:
    instance:
        prefer-ip-address: true #以IP地址注册到服务中心
        instance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port} #eureka实例id
    client:
        service-url:
            defaultZone: http://server1-IP:8761/eureka/,http://server2-IP:8761/eureka/ #微服务注册中心地址

3.4 启动步骤及配置成功检查

先启动注册中心1,注册中心2,然后启动其他的微服务

每个注册中心的available-replicas都出现另外的注册中心的服务,则说明搭建成功。

如图:
在这里插入图片描述

4.Zone和Regions使用(分区多机房部署)

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

  • region:可以简单理解为地理上的分区,比如亚洲地区,或者华北地区,再或者北京等等,没有具体大小的限制。根据项目具体的情况,可以自行合理划分region。
  • zone:可以简单理解为region内的具体机房,比如说region划分为北京,然后北京有两个机房,就可以在此region之下划分出zone1,zone2两个zone。

另外:
1、Region和Zone是一对多的关系。
2、服务注册和发现都会按先指定的Region,然后根据指定的Region寻找第一个Zone。
3、Zone相当于组成Region的基本单元。
如下为分区服务的部署架构图:
在这里插入图片描述

一个region:beijing,下面有zone-1和zone-2两个分区,每个分区内有一个注册中心Eureka Server和一个服务提供者Service。我们在zone-1内创建一个
Consumer-1服务消费者的话,其会优先调用同一个zone内的Service-1,当Service-1不可用时,才会去调用zone-2内的Service-2

4.1 配置zone1和zone2

新建两个application.yml的zone配置文件
1:新建application-zone1.yml文件,配置如下:

spring:
    application:
        name: registry-server-zone-1 # 应用名称
server:
    port: 8761 # 应用启动端口
eureka:
    client:
        # 默认为true,优先选择client实例所在的zone的服务
        prefer-same-zone-eureka: true
        # 区域
        region: cn-east-chengdu
        availability-zones:
            cn-east-chengdu: zone-1,zone-2
        service-url:
            # Eureka Server地址
            zone-1: http://127.0.0.1:8761/eureka/
            zone-2: http://127.0.0.1:8762/eureka/

2:新建application-zone2.yml文件,配置如下:


spring:
    application:
        name: registry-server-zone-2 # 应用名称
server:
    port: 8762 # 应用启动端口
eureka:
    client:
        # 默认为true,优先选择client实例所在的zone的服务
        prefer-same-zone-eureka: true
        # 区域
        region: cn-east-chengdu
        availability-zones:
            cn-east-chengdu: zone-2,zone-1
        service-url:
            zone-1: http://127.0.0.1:8761/eureka/
            zone-2: http://127.0.0.1:8762/eureka/

4.2 启动zone1和zone2

java -jar registry-server -1.0.0.RELEASE.jar --spring.profiles.active=zone1
java -jar registry-server -1.0.0.RELEASE.jar --spring.profiles.active=zone2
启动应用,在http://localhost:8761和http://localhost:8762中均已看到使用zone已经注册成功
在这里插入图片描述

上图注册中心地址为http://localhost:8762
在这里插入图片描述

上图注册中心地址为:http://localhost:8761

4.3 应用接入zone方式的注册中心

修改应用配置文件

eureka:
    instance:
        # 以IP地址注册到服务中心
        prefer-ip-address: true
    client:
        # 注册自身到Eureka
        register-with-eureka: true
        # 拉取Eureka注册信息
        fetch-registry: true
        availability-zones:
            cn-east-chengdu: zone-1,zone-2
        # Eureka Server地址
        serviceUrl:
            zone-1: http://localhost:8761/eureka/
            zone-2: http://localhost:8762/eureka/

启动应用,在http://localhost:8761和http://localhost:8762中均已看到使用zone已经注册成功

在这里插入图片描述

上图注册中心地址为:http://localhost:8761

在这里插入图片描述

上图注册中心地址为:http://localhost:8762

如果在eclipse上进行操作,在application.yml中添加spring.profiles.active节点,当第一次启动当前注册中心应用时,该节点的值为zone1,当再次启动当前注册中心应用时该节点属性的值为zone2;

spring:
    profiles:
        active: zone1

4.4 配置文件详解

整个分区分为两步:

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

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

1、服务注册的配置文件

eureka:  
    client:
        prefer-same-zone-eureka: true #地区  
        region: cn-east-chengdu  
        availability-zones:  
            cn-east-chengdu: zone-1,zone-2  
        service-url:  
            zone-1: http://localhost:8761/eureka/  
            zone-2: http://localhost:8762/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内的服务提供者。

4.5 多机房自动切换

我们在zone-1内创建一个Consumer-1服务消费者的话,其会优先调用同一个zone内的Service-1,当Service-1不可用时,才会去调用zone-2内的Service-2。

service-1和service-2为同一服务部署两个节点,只需更改端口及eureka配置

Service-1测试代码

@RestController
public class HiController {
    @Value("${zone.name}")
    private String zoneName;
     
    @RequestMapping(value = "/hi", method = RequestMethod.GET)
    public String hi() {
        return zoneName;
    }
}

service-1配置

eureka:
    instance:
        hostname: ${spring.cloud.client.ipaddress}
        prefer-ip-address: true
        metadata-map:
            zone: zone-1
    client:
        # 注册自身到Eureka
        register-with-eureka: true
        # 拉取Eureka注册信息
        fetch-registry: true
        prefer-same-zone-eureka: true
        #地区
        region: cn-east-chengdu
        availability-zones:
            cn-east-chengdu: zone-1,zone-2
        service-url:
            zone-1: http://127.0.0.1:8761/eureka/
            zone-2: http://127.0.0.1:8762/eureka/
zone.name: zone-1

service-2 配置

eureka:
    instance:
        hostname: ${spring.cloud.client.ipaddress}
        prefer-ip-address: true
        metadata-map:
            zone: zone-2
    client:
        # 注册自身到Eureka
        register-with-eureka: true
        # 拉取Eureka注册信息
        fetch-registry: true
        prefer-same-zone-eureka: true
        #地区
        region: cn-east-chengdu
        availability-zones:
            cn-east-chengdu: zone-2,zone-1
        service-url:
            zone-1: http://127.0.0.1:8761/eureka/
            zone-2: http://127.0.0.1:8762/eureka/
zone.name: zone-2

Consumer-1测试代码


@RestController
public class HiController {
    @Autowired
    private RestTemplate restTemplate;
 
    @RequestMapping(value="/consumer")
    public String hi() {
        // 此处的service为服务一和服务二的服务名,不能用ip加端口,并且服务名和eureka注册的一致,注意大小写。
        return restTemplate.getForObject("http://service/hi", String.class);
    }
}

Consumer-1的配置

eureka:
    instance:
        prefer-ip-address: true
        metadata-map:
            zone: zone-1
    client:
        # 注册自身到Eureka
        register-with-eureka: true
        # 拉取Eureka注册信息
        fetch-registry: true
        prefer-same-zone-eureka: true
        #地区
        region: cn-east-chengdu
        availability-zones:
            cn-east-chengdu: zone-1,zone-2
        service-url:
            zone-1: http://127.0.0.1:8761/eureka/
            zone-2: http://127.0.0.1:8762/eureka/

效果演示
可以看到Consumer-1优先调用的是同一个zone-1的Service-1,这个时候,无论怎么刷新,调用多少次,都只会调用Service-1,不会调用Service-2。
在这里插入图片描述

当我们把Service-1服务停掉,再调用的话,才会调用zone-2分区下的Service-2。
在这里插入图片描述

5 工程源码

zone工程源码参考附件(修改配置文件中的端口、eureka、redis、数据库连接地址后即可运行)
链接: https://pan.baidu.com/s/1M1EFBeNNm0uUdueswTp3Rg 提取码: zr7j

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值