Eureka的使用场景

前言:

微服务技术的第一步就是对项目进行拆分,就是把一个单体项目,拆分成多个独立的项目,我们把这种独立的项目称为一个服务,一个大型的项目往往包含数百甚至上千的服务形成一个服务集群。如图:

一个业务可能是由多个服务共同完成,例如服务A调用服务B,服务B调用服务C,当一个业务功能比较复杂的时候这些服务之间的调用关系就会变得越来越复杂,如图:

这么复杂的关系如果单靠人来记录或者维护,那是非常困难的,想想都麻。因此微服务中一定会有一个组件来代替我们干这种事情,它就是注册中心,例如Eureka,作用是记录微服务集群中,每一个服务的ip、端口以及服务的功能。

在服务集群里面每一独立的项目都有自己的配置文件,将来如果需要更改配置就非常麻烦,因此就用了配置中心。实现配置热更新

微服务的远程调用

提供者与消费者

服务提供者是指在一次业务中,被其他微服务调用的业务

服务消费者是指在一次业务中,调用其他服务的服务。

ps:a调用b,b调用c那b到底是什么?

答:对应a来说b是提供者,对于c来说b是消费者,这两个概念是相对与业务的,一个服务既可以是提供者也可以是消费者。

Eureka注册中心

Eureka的作用

每一个服务启动时都会向euraka-server 注册服务信息,如果服务消费者需要调用某一个服务会向eureka-server拉取服务,传统的两个独立的项目之间的调用可以通过硬编码的形式如端口号+虚拟映射路径来调用提供者。但是会面临下面三个问题,eureka可以很好的解决这三个问题。

服务消费者如何获取服务提供者的地址信息?

每一个服务启动时都会向eureka-server 注册服务信息,eureka会保存这些信息,如果服务消费者需要调用某一个服务会向eureka-server拉取服务(根据服务名称)

如果有多个服务提供者,消费者该如何选择?

通过负载均衡算法,从服务列表挑选一个。

消费者如何得知服务提供者的健康状态?

服务每个30s会向eureka-server发一次心跳,来确认自己的状态,如果没有跳,就会将其抹除,服务消费者调用的时候就不会拉去该服务提供者。

相关推荐
一 乐8 分钟前
医疗管理|医院医疗管理系统|基于springboot+vue医疗管理系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·医疗管理系统
华仔啊23 分钟前
SpringBoot 2.x 和 3.x 的核心区别,这些变化你必须知道
java·spring boot·后端
啟明起鸣28 分钟前
【Go 与云原生】让一个 Go 项目脱离原生的操作系统——我们开始使用 Docker 制造云容器进行时
docker·云原生·golang
laocooon52385788629 分钟前
大数的阶乘 C语言
java·数据结构·算法
不见长安在41 分钟前
分布式ID
java·分布式·分布式id
熊小猿44 分钟前
Redis 缓存怎么更新?—— 四种模型与一次“迟到的删除”
java·后端·spring
TDengine (老段)1 小时前
从细胞工厂到智能制造:Extracellular 用 TDengine 打通数据生命线
java·大数据·数据库·科技·制造·时序数据库·tdengine
Boop_wu1 小时前
[Java EE] 多线程 -- 初阶(1)
java·jvm·算法
西岭千秋雪_3 小时前
Zookeeper实现分布式锁
java·分布式·后端·zookeeper·wpf
MarcoPage4 小时前
Python 字典推导式入门:一行构建键值对映射
java·linux·python