Eureka:Spring Cloud服务注册和发现组件

问题总结

  1. Eureka 两大组件?
  2. Eureka 服务注册与发现?
  3. Eureka Server 集群?
  4. Eureka 自我保护机制?

问题答案

  1. Eureka 两大组件
  • Eureka Server:Eureka 服务注册中心。当微服务启动时,会将自己的服务注册到Eureka Server。Eureka Server维护了一个可用服务列表,存储了所有注册到Eureka Server的可用服务。
  • Eureka Client:Eureka 客户端,微服务系统中的各个微服务。Eureka Client会向Eureka Server发送心跳(默认30s)。Eureka Server在多个心跳周期没有收到Eureka Client的心跳,将其从服务列表中移除(默认90s)。

  1. Eureka 服务注册与发现

图1:

  • 服务注册中心(Register Service):Eureka Server,提供服务注册和发现功能。
  • 服务提供者(Provider Service):Eureka Client,提供服务。将自己注册到Register Service,以供服务消费者发现。
  • 服务消费者(Consumer Service):Eureka Client,提供消费服务。从Register Service获取服务列表,调用所需服务。

Eureka流程:

  1. 搭建一个Eureka Server作为服务中心;
  2. 服务提供者Eureka Client启动时,将当前服务器的信息以服务名(spring.application.name)的方式注册到服务注册中心;
  3. 服务消费者Eureka Client启动时,向服务注册中心注册;
  4. 服务消费者获取一份可用服务列表,包含了所有注册到服务注册中心的服务信息(包括服务提供者和自身的信息);
  5. 服务消费者通过HTTP或消息中间件远程调用服务提供者提供的服务。

  1. Eureka Server 集群
  • Eureka Server A 和 Eureka Server B,将A作为一个服务注册到B上,B注册一个服务到A上。形成一个相互注册的Eureka Server集群,当服务提供者发送注册请求到Eureka Server时,Eureka Server会将请求转发给集群中与之相连的Eureka Server上,形成Eureka Server之间的服务同步。
  • 服务消费者可以在集群中的任意一台Eureka Server上获取服务提供者的服务。当集群中某个服务注册中心发生故障,服务消费者仍然可以从集群中其他Eureka Server获取服务信息并调用,而不会导致系统的整体瘫痪。(高可用)

  1. Eureka 自我保护机制
  • 在实际的分布式微服务中,健康的服务(Euraka Client)可能因为网络故障而无法与Eureka server正常通讯。若此时Eureka Server因为没有接受心跳而误将健康的服务从服务列表中移除,这显然不合理。
  • Eureka Server在一段时间内没有接收到Eureka Client的心跳,那么Eureka开启自我保护机制,将所有Eureka Cilent的注册信息保护起来。一但网络恢复,这些Eureka Client提供的服务能够继续被服务消费者消费。
    • 弊端:在Eureka自我保护机制触发期间,服务提供者提供的服务出现问题,那么服务消费者就很容易获取到已经不存在的服务从而出现调用失败的情况。(通过Ribbon:负载均衡+Hystrix:流量控制、熔断机制)

Eureka:Spring Cloud服务注册和发现组件的更多相关文章

  1. Spring Cloud ---- 服务注册与发现(Eureka 找到了!找到了! 嘻嘻)

    记录一下吧,为什么接触分布式.因为裸辞之后没有找到工作,好的公司都要求有分布式经验,但是我完全没有.在一次面试的时候,面试官说如果你会分布式架构的话,我可以把工资给你开高2.5,我就考虑着给我点时间, ...

  2. spring cloud服务注册与发现无法发现的可能原因

    1.注册中心服务端默认90秒检测一次,看服务是否还存活,不存活则删除掉服务,还存活则继续注册上去 2. spring: profiles: dev cloud: config: name: clean ...

  3. 一起来学Spring Cloud | 第二章:服务注册和发现组件 (Eureka)

    本篇文章,很浅显的一步步讲解如何搭建一个能运行的springcloud项目(带所有操作截图).相信!看完本篇之后,你会觉得springcloud搭建如此简单~~~~ 一. Eureka简介: 1.1  ...

  4. spring cloud 服务注册中心eureka高可用集群搭建

    spring cloud 服务注册中心eureka高可用集群搭建 一,准备工作 eureka可以类比zookeeper,本文用三台机器搭建集群,也就是说要启动三个eureka注册中心 1 本文三台eu ...

  5. spring Cloud服务注册中心Eureka集群

    spring Cloud服务注册中心Eureka集群配置: 在application.yml文件加以下配置: server: port: 8761 tomcat: uri-encoding: UTF- ...

  6. Spring Cloud服务注册中心交付至kubernetes

    前言 服务发现原则: 各个微服务在启动时,会将自己的网络地址等信息注册到服务发现组件中,服务发现组件会存储这些信息 服务消费者可以从服务发现组件中查询到服务提供者的网络地址,并使用该地址来远程调用服务 ...

  7. .net core + eureka + spring boot 服务注册与调用

    .net core + eureka + spring boot 服务注册与简单的调用 假期小长假遇上疫情只能去家里蹲了,刚好有时间总结一下. 概述 微服务架构是当前比较火的分布式架构,本篇基于.ne ...

  8. spring boot 2.0.3+spring cloud (Finchley)1、搭建服务注册和发现组件Eureka 以及构建高可用Eureka Server集群

    一 .搭建Eureka 编写Eureka Server 由于有多个spring boot项目,采用maven多module的结构,项目结构如下: 新建一个maven主工程,在主maven的pom文件中 ...

  9. 孰能巧用 Spring Cloud 服务注册中心Eureka

    Eureka介绍 在Spring Cloud Netflix 整合技术栈中,Eureka既可以作为服务注册中心也可以用于服务发现对整个微服务架构起着最核心的整合作用. Eureka是基于REST(Re ...

  10. 微服务~Eureka实现的服务注册与发现及服务之间的调用

    微服务里一个重要的概念就是服务注册与发现技术,当你有一个新的服务运行后,我们的服务中心可以感知你,然后把加添加到服务列表里,然后当你死掉后,会从服务中心把你移除,而你作为一个服务,对其它服务公开的只是 ...

随机推荐

  1. 20230919 .NET面经

    SQL IQuerable 和 IEnumerable 的主要区别? https://stackoverflow.com/questions/252785/what-is-the-difference ...

  2. proto转java类时相关option配置

    转载请注明出处: option java_multiple_files = true; 作用和意义:此选项指示生成的 Java 代码将被分割成多个文件而不是一个文件.每个消息类型都会生成一个单独的 J ...

  3. 个人理解strcpy

    char * strcpy(char *dst,const char *src) { if((dst==NULL)||(src==NULL)) return NULL; char *ret = dst ...

  4. MySQL 的 InnoDB 存储引擎简介

    MySQL 是世界上最流行的开源关系型数据库管理系统之一,而其中的存储引擎则是其关键组成部分之一.InnoDB 存储引擎在 MySQL 中扮演了重要角色,提供了许多高级功能和性能优化,适用于各种应用程 ...

  5. nacos-mysql.sql

    https://github.com/alibaba/nacos/blob/master/distribution/conf/nacos-mysql.sql # Nacos安装 /home/nacos ...

  6. MySQL中sql_mode的设置

    在升级MySQL版本到8.0的过程中,需要关注sql_mode参数默认值的变化,8.0版本sql_mode不支持 NO_AUTO_CREATE_USER,要避免配置的sql_mode中带有 NO_AU ...

  7. 洛谷 P9518 queue

    一眼模拟. 需要维护的东西可以根据操作求得: start:正在玩游戏的 \(1\) 或 \(2\) 个人: arrive:当前在排队但没玩游戏的队列.每个人是否在排队.游玩: leave:每个人是否在 ...

  8. 立方骑士(lgP7354)

    来水篇题解((( 图炸了,去洛谷博客看吧. 注:在本篇题解中, \(K\) 表示国王, \(N\) 表示骑士,不同颜色的 \(X\) 表示该位置国王可以达到,且被与之相同颜色的骑士封锁.方法不唯一,图 ...

  9. Redis 7.0 源码环境搭建与阅读技巧

    天下武功,无坚不摧,唯快不破!我的名字叫 Redis,全称是 Remote Dictionary Server. 有人说,组 CP,除了要了解她外,还要给机会让她了解你. 那么,作为开发工程师的你,是 ...

  10. Leetcode.456单调栈

    给你一个整数数组 nums ,数组中共有 n 个整数.132 模式的子序列 由三个整数 nums[i].nums[j] 和 nums[k] 组成,并同时满足:i < j < k 和 num ...