前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Eureka详解

Eureka详解

作者头像
用户1134788
发布于 2022-05-09 02:19:34
发布于 2022-05-09 02:19:34
4240
举报

该章节紧接第三章,主要是对一些理论上的指导,帮助更好的理解服务治理。

基础架构

  eureka服务治理的基础架构包含三个要素:

  1)服务注册中心:eureka提供服务端,提供服务的注册与发现功能。

    注:在配置注册中心时,记得避免注册中心向自己注册,需要在配置文件中添加:

      eureka.client.register-with-eureka=false(这个是避免eureka向自己进行注册)

      eureka.client.fetch-registry=false(这个是避免eureka查找服务列表)

  2)服务提供者:提供服务的应用,可以是springboot应用,也可以是其他技术平台且遵循Eureka通信机制的应用,可以将自己的服务注册到Eureka上。

  3)服务消费者:消费者应用从服务注册中心获取服务列表,从而使消费者知道去哪调用所需要的服务。

服务治理机制

服务提供者

  服务注册:

  “服务提供者”在启动的时候会发送REST请求将自己注册到Eureka Server上,并带上一些元信息。

  Eureka Server接收到REST请求,将元信息存储在一个双层Map中,第一层key是服务名,第二层key是具体服务的实例名。

  注:在服务注册时,需要确认一下eureka.client.register-with-eureka=true是否正确,如果为false是禁止向Eureka Server注册的。

  服务同步:

  不同的服务提供者分别注册到了一个注册中心集群上的不同的注册中心上。他们的信息被不同的注册中心维护。

  由于在集群中,一个注册中心互为其他注册中心的服务,当服务提供者请求到一个服务注册中心后,它会将请求转发到其他服务注册中心,实现注册中心之间的服务同步。

  通过服务同步,服务提供者的服务信息可以通过集群中的任何一个注册中心获取。

  服务续约:

  在注册完成后。服务提供者会维护一个心跳告诉注册中心服务政策,防止注册中心剔除服务,该过程称为服务续约。

  eureka.instance.lease-renewal-interval-in-seconds参数用于定义:服务续约任务的调用间隔时间,默认30s。

  eureka.instance.lease-expiration-duration-in-seconds参数用于定义:服务失效时间,默认30s。

服务消费者

  获取服务:

  启动服务消费者后,会发送一个REST请求给服务注册中心,来获取上面注册的服务清单。

  Eureka Server会维护一份只读清单返回给消费者客户端,该缓存清单30s更新一次。

  注:在服务获取时,确定eureka.client.fetch-registry=true,设置成false,服务客户端不会再向注册中心发送请求。

  缓存清单的时间配置:eureka.client.registry-fetch-internal-seconds=30s

  服务调用:

  消费者获取服务清单后,可以通过服务名获取到具体服务实例与实例的元数据信息。在Ribbon中默认采用轮询的方式进行调用,从而实现负载均衡

  服务下线:

  当服务实例进行正常的关闭操作时,它会触发一个服务下线的REST请求给Eureka Server。注册中心接收到请求后,将该服务状态置为DOWN,并把下线时间传播出去。

服务注册中心

  失效剔除:

  Eureka Server启动时会创建定时任务,默认60s一次,将当前清单中超时(90s)没有续约的服务剔除。

  自我保护:

  本地调试Eureka的程序时,会出现: 

  该警告是触发了Eureka Server的自我保护机制。

  Eureka Server在运行期间,会统计心跳失败的比例在15分钟之内是否低于85%,如果低于,就会将当前实例注册信息保护起来,让实例不会过期,尽可能保护这些注册信息。

  但是如果在保护期间,实例出现问题,那么客户端很容易拿到实际已经不存在的服务实例,会出现调用失败。这个时候客户端的容错机制就很重要了。(重新请求,断路器)

  保护机制,可能会导致服务实例不能够被正确剔除。

  在本地开发时,可使用:eureka.server.enable-self-preservation=false关闭保护机制,使不可用实例能够正常下线。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-01-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
碎碎念之Eureka的一些概念性知识
Spring Cloud Eureka是Spring Cloud Netflix中的一部分,基于Netflix Eureka做了二次封装,主要负责微服务架构中的服务治理。
JathonKatu
2020/10/27
3590
Eureka服务注册与发现
注意: 保护机制在生产环境中,通常是为了防止因网络原因而导致原本没有问题的服务被清除。而如果真的是大面积服务失效,那么久需要服务容错机制了,往后会提到的熔断器。因此一旦开启了保护机制,则服务注册中心维护的服务实例就不是那么准确了。 关于自我保护机制更深入了解,可参考Spring Eureka自我保护机制
呆呆
2021/08/01
3210
Eureka中的核心概念
本文是Spring Cloud系列的第四篇,前面三篇文章(使用Spring Cloud搭建服务注册中心、使用Spring Cloud搭建高可用服务注册中心、Spring Cloud中服务的发现与消费)我们带大家搭建了服务注册中心,向服务注册中心注册了服务,同时也发现和消费了服务。前面的文章我们是以实际代码操作为主,这篇文章我想对前面三篇文章中涉及到的一些知识点再进行详细的梳理,对于一些前面未涉及到的配置再做进一步的说明。 首先,通过前面三篇文章的学习,小伙伴们已经发现了Eureka服务治理体系中涉及到三个核
江南一点雨
2018/04/02
9670
Eureka中的核心概念
Spring Cloud微服务技术栈(三):服务治理Spring Cloud Eureka核心元素分析
通过前面的文章的了解,我们知道Eureka服务治理包含了服务注册中心、服务提供者和服务消费者三个核心元素,三者的基本关系是:服务注册中心提供服务注册和服务发现平台,服务提供者将服务注册到服务注册中心,服务消费者从服务注册中心获取服务实例列表并调用。下图展示了三者之间的关系:
itlemon
2020/04/03
4370
Spring Cloud微服务技术栈(三):服务治理Spring Cloud Eureka核心元素分析
Spring Cloud Eureka 原理浅析
机制:将自己作为注册中心向其他服务注册中心注册自己,这样就可以形成一组互相注册的服务注册中心。 实现:
用户5546570
2019/06/06
1.3K0
Spring Cloud Eureka 原理浅析
Spring Cloud Eureka详解
服务治理是微服务架构中最为核心和基础的模块,它主要用来实现各个微服务实例的自动化注册和发现。
全栈程序员站长
2022/09/14
7970
Spring Cloud Eureka详解
springcloud原理详解_SpringMVC运行原理
  Eureka服务治理的基础架构包含三个核心:服务注册中心、服务提供者、服务消费者。其中服务注册中心,即Eureka提供的服务端,提供服务注册和发现的功能;服务提供者,即将自己的服务注册到注册中心;服务的消费者,从注册中心获取服务列表,从而使消费者知道到何处调用服务,服务消费可以使用Ribbon、Feign等。
全栈程序员站长
2022/11/01
4990
springcloud学习手册-Eureka(第一节)
导读 |Springcloud Eureka 服务治理 一、服务治理:Springcloud Eureka Eureka是springcloud Netflix服务套件中的一部分。它主要负责完成微服
程序源代码
2018/03/09
7970
springcloud学习手册-Eureka(第一节)
Eureka集群(Eureka详解)
上篇文章,我们已经搭建了微服务的框架,使用了SOA(服务治理)Eureka 参考:Eureka注册中心 这篇文章教大家,如何使用IDEA搭建SpringCloud的集群,Spring拥有最简单的搭建集群方法
全栈程序员站长
2022/08/23
1.6K0
Eureka集群(Eureka详解)
微服务架构下的服务治理:在 SpringCloud 框架中实现服务的注册与发现
服务治理 RPC远程过程调用协议的核心设计思想: 在于注册中心, 因为注册中心:管理每个服务与服务之间的一个依赖关系 服务治理: 在传统的RPC远程过程调用协议中,管理每个服务与服务之间的依赖关系非常复杂.可以使用服务治理技术,管理每个服务与服务之间的一个依赖关系.可以实现本地负载均衡,服务发现与注册,容错等 服务注册与发现 注册中心 在RPC远程过程调用协议中,有一个注册中心 SpringCloud支持三种组册中心: Consul(go语言) Eureka Zookeeper Dubbo支持两种注册中心:
攻城狮Chova
2021/08/17
8570
微服务架构下的服务治理:在 SpringCloud 框架中实现服务的注册与发现
Spring Cloud Eureka集群
Spirng Cloud Eureka使用Netflix Eureka来实现服务注册与发现。它既包含了服务端组件,也包含了客户端组件,并且服务端与客户端均采用java编写,所以Eureka主要适用于通过java实现的分布式系统,或是JVM兼容语言构建的系统。Eureka的服务端提供了较为完善的REST API,所以Eureka也支持将非java语言实现的服务纳入到Eureka服务治理体系中来,只需要其他语言平台自己实现Eureka的客户端程序。目前.Net平台的Steeltoe、Node.js的eureka-js-client等都已经实现了各自平台的Ereka客户端组件。
全栈程序员站长
2022/08/18
4600
Spring Cloud Eureka集群
Spring Cloud核心组件详解
1)、Eureka服务端:也称服务注册中心,同其他服务注册中心一样,支持高可用配置。如果Eureka以集群模式部署,当集群中有分片出现故障时,那么Eureka就转入自我保护模式。它允许在分片故障期间继续提供服务的发现和注册,当故障分片恢复运行时,集群中其他分片会把它们的状态再次同步回来
全栈程序员站长
2022/09/14
1.8K0
Spring Cloud核心组件详解
Spring Cloud Eureka 详述(一)
服务治理: Spring Cloud Eureka一、简介二、 功能概述服务治理Netflix Eureka搭建服务注册中心注册服务提供者高可用配置中心服务发现与消费
cxuan
2019/06/03
9490
SpringCloud学习1-服务注册与发现(Eureka)
前言 Oracle转让Java,各种动态语言的曝光率上升,Java工程师的未来在哪里?我觉得Spring Cloud让未来有无限可能。拖了半年之久的Spring Cloud学习就从今天开始了。中文教材不多,而且大多都是简单的离散的信息,想要找到企业级的一体化解决方案很少。不过,对于入门来说,简单就够了,等到用的时候自然而然的汇总起来。 目标是把springcloud的子项目过一遍。 Component Edgware.SR2 Finchley.M7 Finchley.BUILD-SNAPSHOT
Ryan-Miao
2018/03/14
2.5K0
SpringCloud学习1-服务注册与发现(Eureka)
了解Eureka工作原理
Eureka 作为 Spring Cloud 体系中最核心、默认的注册中心组件,研究它的运行机制,有助于我们在工作中更好地使用它。
chengcheng222e
2021/11/04
1.5K0
深入理解 Spring Cloud 核心组件 底层原理
之前一直在看 Spring Cloud 及微服务架构 对 Spring Cloud 的主要组件的原理有了更深入一点的理解,特地做一下总结。
搜云库技术团队
2019/11/18
1.6K0
Spring Cloud 之 Eureka.
 简单地说, 微服务是系统架构上的一种设计风格, 它的主旨是将一个原本独立的系统拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间基于 RPC 进行通信协作。 被拆分成的每一个小型服务都围绕着系统中的某一项或一些耦合度较高的业务功能进行构建, 并且每个服务都维护着自身的数据存储(划重点,每个微服务都有自己的数据库实例)、 业务开发、自动化测试案例以及独立部署机制。
JMCui
2019/06/28
4700
Eureka特性及高可用注册中心集群搭建
- 服务提供者在启动时向Eureka Server(服务注册中心)发送注册请求,将自己的服务ID、主机地址、端口、健康检查URL等元数据信息注册到Eureka Server。
用户7353950
2024/04/19
5020
Eureka特性及高可用注册中心集群搭建
微服务之服务治理_Eureka
首先需要明确,不管是什么事物需要”治理“,那一定是该事物存在一定问题。比如环境治理。那么服务,或者说微服务为什么需要治理?对于服务来说,如果它承担的业务职责简单,那其实治理的必要性不大,因为服务运行过程是相对透明的,即使出现问题也能较快发现、定位、回滚。当服务承担的业务职责变多变大,那随着更多问题的到来,服务治理开始变得必要。服务治理也与技术架构本身息息相关。
炒香菇的书呆子
2023/10/09
3570
快速学习-Eureka注册中心
在刚才的案例中,user-service对外提供服务,需要对外暴露自己的地址。而consumer(调用者)需要记录服务提供者的地址。将来地址出现变更,还需要及时更新。这在服务较少的时候并不觉得有什么,但是在现在日益复杂的互联网环境,一个项目肯定会拆分出十几,甚至数十个微服务。此时如果还人为管理地址,不仅开发困难,将来测试、发布上线都会非常麻烦,这与DevOps的思想是背道而驰的。
cwl_java
2020/02/11
6360
相关推荐
碎碎念之Eureka的一些概念性知识
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档