eureka架构以及集群

eureka架构三大核心:

  • 服务注册中心: eureka
    Eureka的服务端应用,提供服务注册和发现功能,就是刚刚我们建立的eureka-server
  • 服务提供者 consumer
    提供服务的应用,可以是SpringBoot应用,也可以是其它任意技术实现,只要对外提供的是Rest风格服务即可
  • 服务消费者 service
    消费应用从注册中心获取服务列表,从而得知每个服务方的信息,知道去哪里调用服务方
    eureka集群配置 :
    多个Eureka Server之间也会互相注册为服务,当服务提供者注册到Eureka Server集群中的某个节点时,该节点会把
    服务的信息同步给集群中的每个节点,从而实现数据同步。因此,无论客户端访问到Eureka Server集群中的任意一
    个节点,都可以获取到完整的服务列表信息(今天刚知道我们的服务器居然用了两个单独的eureka,并没有构成集群,)。
  • 开始了
  • 端口号: 10086 10087
  • 修改配置文件:
Eureka配置

#Eureka端口号
server:
  port: ${port:10086}

#名称
spring:
  application:
    name: eureka-server

#eureka
eureka:
  client:
    service-url:
      #eureka 服务地址,如果是集群的话,需要制定其他集群eureka地址
      defaultZone: ${http://127.0.0.1:10086/eureka}
      #或者
      # defaultZone: http://127.0.0.1:10086/eureka,http://127.0.0.1:10087/eureka      
    # 不注册自己
    #register-with-eureka: false
    # 不拉取服务
    #fetch-registry: false
  • eureka服务端:
  • 服务注册 使用 ip 地址
    默认注册时使用的是主机名或者localhost,如果想用ip进行注册,可以在 user-service 中添加配置如下
在服务端配置

#eureka
eureka:
  instance:
    ip-address: 127.0.0.1  #ip地址
    prefer-ip-address: true #更倾向于使用ip
    lease-expiration-duration-in-seconds: 90 #服务续约(renew)的间隔,默认为30秒
    lease-renewal-interval-in-seconds: 30 #服务失效时间,默认值90秒

默认情况下每隔30秒服务会向注册中心发送一次心跳,证明自己还活着。如果超过90秒没有发送心跳,
EurekaServer就会认为该服务宕机,会定时(eureka.server.eviction-interval-timer-in-ms设定的时间)从服务列表
中移除,这两个值在生产环境不要修改,一般默认即可。
当服务消费者启动时,会检测 eureka.client.fetch-registry=true 参数的值,如果为true,则会从Eureka
Server服务的列表拉取只读备份,然后缓存在本地。并且 每隔30秒 会重新拉取并更新数据。可以在 consumer-demo

  • 消费者配置:
在消费者配置

eureka:
  client:
    registry-fetch-interval-seconds: 30 #每隔30秒 会重新拉取并更新数据,获取服务列表
  • 失效剔除和自我保护
  1. 服务下线
    当服务进行正常关闭操作时,它会触发一个服务下线的REST请求给Eureka Server,告诉服务注册中心:“我要下线
    了”。服务中心接受到请求之后,将该服务置为下线状态.
    2. 失效剔除
    有时我们的服务可能由于内存溢出或网络故障等原因使得服务不能正常的工作,而服务注册中心并未收到“服务下
    线”的请求。相对于服务提供者的“服务续约”操作,服务注册中心在启动时会创建一个定时任务,默认每隔一段时间
    (默认为60秒)将当前清单中超时(默认为90秒)没有续约的服务剔除,这个操作被称为失效剔除。
    可以通过 eureka.server.eviction-interval-timer-in-ms 参数对其进行修改,单位是毫秒。
在Eureka 中配置

#eureka
eureka:
  server:
    # 服务失效剔除时间间隔,默认60秒
    eviction-interval-timer-in-ms: 60000
  1. 自我保护
    这是触发了Eureka的自我保护机制。当服务未按时进行心跳续约时,Eureka会统计服务实例最近15分钟心跳续约的
    比例是否低于了85%。在生产环境下,因为网络延迟等原因,心跳失败实例的比例很有可能超标,但是此时就把服务
    剔除列表并不妥当,因为服务可能没有宕机。Eureka在这段时间内不会剔除任何服务实例,直到网络恢复正常。生
    产环境下这很有效,保证了大多数服务依然可用,不过也有可能获取到失败的服务实例,因此服务调用者必须做好服
    务的失败容错.
在Eureka中配置

eureka:
  server:
  	enable-self-preservation: false # 关闭自我保护模式(缺省为打开)
  • 不愧是你啊diao
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值