eureka配置

一、 服务提供者的配置

服务提供者要向EurekaServer注册服务,并且完成服务续约等工作。

1、 服务注册

服务提供者在启动时,会检测配置属性中的:
eureka.client.register-with-erueka=true参数是否正确,
事实上默认就是true。如果值确实为true,则会向EurekaServer发起一个Rest请求,并携带自己的数据信息,Eureka Server会把这些信息保存到一个双层Map结构中。第一层Map的Key就是服务名称,第二层Map的key是服务的实例id。

2、 服务续约
在注册服务完成以后,服务提供者会维持一个心跳(定时向EurekaServer发起Rest请求)。这个我们称为服务的续约(renew);

3、修改续约

#配置服务端
 eureka:
      instance:
        lease-expiration-duration-in-seconds: 90   #服务失效时间
        lease-renewal-interval-in-seconds: 30	#续约时间

#ease-renewal-interval-in-seconds:服务续约(renew)的间隔,默认为30秒
#lease-expiration-duration-in-seconds:服务失效时间,默认值90秒

4、 实例id

Eureka监控页面status信息:

  • UP(1):代表现在是启动了1个示例,没有集群
  • DESKTOP-2MVEC12:user-service:8081:是实例的名称(instance-id),
    • 默认格式是:
    • ${hostname} + ${spring.application.name} + ${server.port}
    • instance-id是区分同一服务的不同实例的唯一标准,因此不能重复。

可以通过instance-id属性来进行修改

eureka:
  instance:
    instance-id: ${spring.application.name}:${server.port}

二、服务消费者的配置

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

eureka:
  client:
    registry-fetch-interval-seconds: 5		#默认30秒

三、eureka注册中心的配置

server:
  port: 8888
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8888    #对外服务的路径(注册服务的路径)
    fetch-registry: false #不拉取服务列表
    registerWithEureka: false #不要把自己注册成了服务
spring:
  application:
    name: eureka-server

1、失效剔除
有些时候,我们的服务提供方并不一定会正常下线,可能因为内存溢出、网络故障等原因导致服务无法正常工作。
Eureka Server需要将这样的服务剔除出服务列表。因此它会开启一个定时任务,每隔60秒对所有失效的服务(超过90秒未响应)进行剔除。

可以通过eureka.server.eviction-interval-timer-in-ms参数对其进行修改,单位是毫秒,生成环境不要修改。
你对服务重启,隔了60秒Eureka才反应过来。开发阶段可以适当调整,比如10S

2、自我保护
这是触发了Eureka的自我保护机制。当一个服务未按时进行心跳续约时,
Eureka会统计最近15分钟心跳失败的服务实例的比例是否超过了85%。
在生产环境下,因为网络延迟等原因,心跳失败实例的比例很有可能超标,但是此时就把服务剔除列表并不妥当,
因为服务可能没有宕机。

Eureka就会把当前实例的注册信息保护起来,不予剔除。生产环境下这很有效,保证了大多数服务依然可用。

eureka:
  server:
    enable-self-preservation: false # 关闭自我保护模式(缺省为打开)
    eviction-interval-timer-in-ms: 1000 # 扫描失效服务的间隔时间(缺省为60*1000ms)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值