概述
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秒 会重新拉取并更新数据,获取服务列表
- 失效剔除和自我保护
- 服务下线
当服务进行正常关闭操作时,它会触发一个服务下线的REST请求给Eureka Server,告诉服务注册中心:“我要下线
了”。服务中心接受到请求之后,将该服务置为下线状态.
2. 失效剔除
有时我们的服务可能由于内存溢出或网络故障等原因使得服务不能正常的工作,而服务注册中心并未收到“服务下
线”的请求。相对于服务提供者的“服务续约”操作,服务注册中心在启动时会创建一个定时任务,默认每隔一段时间
(默认为60秒)将当前清单中超时(默认为90秒)没有续约的服务剔除,这个操作被称为失效剔除。
可以通过 eureka.server.eviction-interval-timer-in-ms 参数对其进行修改,单位是毫秒。
在Eureka 中配置
#eureka
eureka:
server:
# 服务失效剔除时间间隔,默认60秒
eviction-interval-timer-in-ms: 60000
- 自我保护
这是触发了Eureka的自我保护机制。当服务未按时进行心跳续约时,Eureka会统计服务实例最近15分钟心跳续约的
比例是否低于了85%。在生产环境下,因为网络延迟等原因,心跳失败实例的比例很有可能超标,但是此时就把服务
剔除列表并不妥当,因为服务可能没有宕机。Eureka在这段时间内不会剔除任何服务实例,直到网络恢复正常。生
产环境下这很有效,保证了大多数服务依然可用,不过也有可能获取到失败的服务实例,因此服务调用者必须做好服
务的失败容错.
在Eureka中配置
eureka:
server:
enable-self-preservation: false # 关闭自我保护模式(缺省为打开)
- 不愧是你啊diao
最后
以上就是健壮路人为你收集整理的eureka架构以及集群的全部内容,希望文章能够帮你解决eureka架构以及集群所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复