微服务【SpringCloud】--Eureka Server 高可用配置

本文详细介绍了Eureka Server的高可用配置,包括服务同步原理和集群搭建。通过设置多个Eureka Server节点,每个节点互相注册,确保服务列表的完整同步。此外,还讲解了Eureka客户端如何配置注册到集群,服务续约的概念,以及服务下线、失效剔除和自我保护等关键机制。



1、Eureka Server高可用配置

(1)高可用是什么?

“高可用性”(High Availability)通常来描述一个系统经过专门的设计,从而减少停工时间,而保持其服务的高度可用性
如:给Eureka Server 搞一个备份

(2)服务同步原理

多个Eureka Server之间也会互相注册为服务,当服务提供者注册到Eureka Server集群中的某个节点时,该节点会把服务的信息同步给集群中的每个节点,从而实现数据同步
因此,无论客户端访问到Eureka Server集群中的任意一个节点,都可以获取到完整的服务列表信息。

Eureka高可用配置

  • (1)有三个分别为10086、10087、10088
  • (2)具体注册规划
    10086要注册到10087和10088上
    10087要注册到10086和10088上
    10088要注册到10086和10087上
    在这里插入图片描述

Eureka服务端高可用配置(1)

  • (1)假设要搭建两台EurekaServer的集群
    端口分别为:10086和10087
  • (2)操作步骤

把register-with-eureka和fetch-registry修改为true或者注释掉
${}表示在jvm启动时候若能找到对应port或者defaultZone参数则使用,若无则使用后面的默认值
把service-url的值改成了另外一台EurekaServer的地址,而不是自己

${port:10086} 取VM options的值 -Dport=10086
把service-url的值改成了另外一台EurekaServer的地址,而不是自己
在这里插入图片描述

Eureka服务端高可用配置(2)

(1)客户端注册服务到集群
因为EurekaServer不止一个,因此 provider项目注册服务或者consumer 获取服务的时候,service-url参数需要修改为如下:
provider application.properties

eureka.client.service-url.defaultZone=http://127.0.0.1:10086/eureka,http://127.0.0.1:10087/eureka

consumer application.properties

eureka.client.service-url.defaultZone=http://127.0.0.1:10086/eureka,http://127.0.0.1:10087/eureka

Eureka客户端与服务配置

(1)Eureka客户端工程

  • 1 服务提供
    服务地址使用ip方式
    续约
  • 2 服务消费:获取服务地址的频率

(2)Eureka服务端工程 eureka-server

  • 失效剔除
  • 自我保护

Eureka客户端使用ip

(1)默认注册时使用的是主机名或者localhost,如果想用ip进行注册,可以在user-service 中添加配置如下:

eureka.instance.ip-address=127.0.0.1 # 设置当前的ip
eureka.instance.prefer-ip-address=true # 是否ip优名

重启,在调用服务的时候就已经变成ip地址;
需要注意的是:不是在eureka中的控制台服务实例状态显示。

 //获取 provider ip与端口
        List<ServiceInstance> list = discoveryClient.getInstances("demo01_provider_user_8001");//服务id
        //表示运行中的服务对象
        ServiceInstance serviceInstance = list.get(0);
        String host = serviceInstance.getHost();
        int port = serviceInstance.getPort();
        log.info("host "+host);
        log.info("port "+port);

Eureka客户端服务续约

什么叫服务续约

在注册服务完成以后,服务提供者会维持一个心跳
(定时向EurekaServer发起Rest请求)
告诉EurekaServer:我还活着”。这个我们称为服务的续约(renew)
有两个重要参数可以修改服务续约的行为;可以在中添加如下配置项:
lease-renewal-interval-in-seconds:服务续约(renew)的间隔,默认为30秒、
心跳包的时间间隔
lease-expiration-duration-in-seconds:服务失效时间,默认值90秒
没收到心跳包的最长时间

eureka.instance.lease-renewal-interval-in-seconds=30 # 时间间隔
eureka.instance.lease-expiration-duration-in-seconds=90 # 最长时间

Eureka获取服务列表fetch

(1)当服务消费者启动时,会检测eureka.client.fetch-registry=true 参数的值,如果为true,则会从Eureka Server服务的列表拉取只读备份,然后缓存在本地。并且每隔30秒 会重新拉取并更新数据。

eureka.client.registry-fetch-interval-seconds=30

设置消费端可以定时获取注册中心的服务列表,并缓存时间

Eureka 服务端设置

(1)服务下线

当服务进行正常关闭操作时,它会触发一个服务下线的REST请求给Eureka Server,告诉服务注册中心:“我要下线了”。服务中心接受到请求之后,将该服务置为下线状态。

(2)失效剔除

有时我们的服务可能由于内存溢出或网络故障等原因使得服务不能正常的工作,而服务注册中心并未收到“服务下线”的请求。相对于服务提供者的“服务续约”操作,服务注册中心在启动时会创建一个定时任务,默认每隔一段时间(默认为60秒)将当前清单中超时(默认为90秒)没有续约的服务剔除,这个操作被称为失效剔除。
eureka.server.eviction-interval-timer-in-ms 参数对其进行修改,单位是毫秒。

eureka.server.eviction-interval-timer-in-ms=9000

失效讲的就是 删除非正常关闭的服务在注册中心的记录

Eureka 服务端设置

(3)自我保护

我们关停一个服务,很可能会在Eureka面板看到一条警告:
在这里插入图片描述

eureka.server.enable-self-preservation=false

这是触发了Eureka的自我保护机制
eureka.server.enable-self-preservation=false
关闭自我保护模式(缺省为打开)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值