文档章节

F版本SpringCloud 3—大白话Eureka服务注册与发现

鹿老师的Java笔记
 鹿老师的Java笔记
发布于 03/26 20:44
字数 1481
阅读 37
收藏 0

3 月,跳不动了?>>>

引用:服务注册与发现,就像是租房子一样

前言

今天洛阳下雨了,唉,没有想到有裹上了羽绒服,不穿冷穿了热的尴尬温度。上学工作这么多年都在外面,家里竟然没有一件春天的外套。

日常闲聊之后,开始今天的芝士环节。

昨天说过了什么是SpringCloud,提到了SpringCloud实际上是很多技术的合集,今天就来学习第一个技术 Eureka。

大白话服务服务注册与发现

Eureka在微服务的体系中,主要的功能是实现服务治理,服务注册与发现的,那么什么是服务注册与发现呢?

在第一篇文章讲到过,微服务就是将项目中的模块按照业务来进行拆分,如上图,商品是一个独立的服务,订单也是独立的服务,还可以根据需要将订单服务部署为两个。然后商品服务需要使用订单的时候,就去调用订单服务。

但是在上图中有几个问题是需要解决的:

  1. 商品服务想要调用订单服务,怎么知道订单服务1 和 订单服务2的地址?如果临时增加一个订单服务3,那么怎么告诉商品服务订单服务3的地址?
  2. 如果订单服务1宕机了,这个时候商品服务如果不知道,依然选择调用已经宕机的订单服务1,会服务调用失败。也就是说:订单服务1宕机了,如何把这个情况即时的告诉其他所有的服务? ......

解决以上问题的方案就是:引入服务管理者,就是服务治理。

先举一个生活的小栗子:

  • 在没有互联网的时代,如果要租房子需要找中介,中介就是一个服务管理者的角色
  • 我们是租房者,要找房源,这个关系就像是商品服务找订单服务
  • 那么房源怎么来呢?房东在需要出租房子的时候,去找中介,将自己的房源信息登记到中介那里。这个过程叫做注册
  • 我们要租房子,假如说要租两室一厅,首先需要先找中介要所有房源的注册清单,从清单中可以找到两室一厅。这个过程叫做发现。 这个例子可以帮助大家,理解注册和发现两个过程,以及管理者的角色。

通过以上例子我们得到下图:

服务治理的管理者我们称之为注册中心。

**服务注册:**每个服务在启动的时候,告诉注册中心自己的位置信息。

**服务发现:**商品服务想要调用订单服务,先找注册中心获取到所有服务的位置信息,然后找到订单服务的地址,发起调用。

**心跳机制:**服务启动之后,每过30秒向注册中心心跳一次(就是发送一个消息,告诉注册中心自己还活着),如果注册中心长时间没有收到某个服务的心跳,那么就会认为这个服务已经宕机,就从服务注册列表中删除。

什么是Eureka

Spring Cloud封装了Netlix 公司开发的Eureka模块来实现服务治理,管理服务于服务之间依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册。

Eureka 组件

在Eureka的架构中,分为 Eureka Server 和 Eureka client。

Eureka 注册中心 Eureka Server

Eureka Server 作为服务注册功能的服务器,它是服务注册中心。

Eureka Server提供服务注册服务:各个节点启动后,会在EurekaServer中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观的看到(监控页面)

而系统中的其他微服务,使用 Eureka 的客户端连接到 Eureka Server并维持心跳连接。这样系统的维护人员就可以通过 Eureka Server 来监控系统中各个微服务是否正常运行。

Eureka 客户端 Eureka Client

EurekaClient是一个Java客户端,用于简化Eureka Server的交互,客户端同时也具备一个内置的、使用轮询(round-robin)负载算法的负载均衡器。

  • 在应用启动后,将会向Eureka Server发送心跳(默认周期为30秒)。如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,EurekaServer将会从服务注册表中把这个服务节点移除(默认90秒)

  • Eureka Client会缓存服务注册表中的信息。这种方式有一定的优势首先可以降低Eureka Server的压力,其次当所有的Eureka Server宕机服务调用方依然可以完成调用

总结

恭喜你完成了本章的学习,为你鼓掌!如果本文对你有帮助,请帮忙点赞,评论,转发,这对作者很重要,谢谢。

要掌握SpringCloud更多的用法,请持续关注本系列教程。

欢迎关注本人公众号:鹿老师的Java笔记,将在长期更新Java技术图文教程和视频教程,Java学习经验,Java面试经验以及Java实战开发经验。

© 著作权归作者所有

鹿老师的Java笔记
粉丝 0
博文 27
码字总数 58740
作品 0
郑州
程序员
私信 提问
加载中

评论(0)

立足于SpringCloud心法总纲

1、SpringCloud版本 springcloud对应springboot的版本关系 序列号 springcloud版本号 springbooot版本号 H Hoxton 2.2.x G Greenwich 2.1.x F Finchley 2.0.x E Edgware 1.5.x D Dalston 1.......

木九天
2018/12/29
571
0
eureka实战——高可用服务治理框架

本文地址:https://www.jianshu.com/p/9aa452b1def0 代码地址:https://gitee.com/sunnymore/highavailability_eureka grpc实战文章:https://www.jianshu.com/p/87a352ff637b 之前Sunny有聊......

程序员Sunny
2018/06/05
0
0
史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现Eureka(Finchley版本)

版权声明:本文为博主原创文章,欢迎转载,转载请注明作者、原文超链接 ,博主地址:http://blog.csdn.net/forezp。 https://blog.csdn.net/forezp/article/details/81040925 转载请标明出处...

方志朋
2018/07/14
0
0
业余草 SpringCloud 教程 | 第一篇: 服务的注册与发现Eureka(Finchley版本)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/xmt1139057136/article/details/81411887 一、spring cloud简介 鉴于《史上最简单的Spring Cloud教程》很受读...

业余草
2018/08/04
0
0
跟我学Spring Cloud(Finchley版)-05-服务注册与服务发现-Eureka入门

本节讲解基于Eureka的服务发现。 Eureka简介 Eureka是Netflix开源的服务发现组件,本身是一个基于REST的服务,包含Server和Client两部分,Spring Cloud将它集成在子项目Spring Cloud Netfli...

周立_ITMuch
2019/01/03
118
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周日乱弹 —— 和网友的第一次开房经历

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @薛定谔的兄弟 :分享洛神有语创建的歌单「我喜欢的音乐」: 《Ljósið》- Ólafur Arnalds 手机党少年们想听歌,请使劲儿戳(这里) @xiaos...

小小编辑
40分钟前
23
0
程序员职业生涯指引

程序员应该尽早规划自己的职业生涯 为什么写 众所周知 IT 这一行到了一定的年龄、大部分人都或多或少有危机感,特别是今年全国乃至全球发生的疫情、导致整体经济受到很大的影响、这次的疫情影...

科比可比克
54分钟前
11
0
JVM调优实战分析

一、查看服务器项目JVM参数以及参数分析 1、jps 命令 : 列出系统中所有的 Java 应用程序以及PID 如下图所示,26647就是我部署在服务器的一个小项目的 PID 2、jmap命令:查看堆的使用情况 如...

IT-Mamba
今天
29
0
IDEA Tomcat 日志乱码解决汇总

IDEA Tomcat 日志乱码解决汇总 第三种没解决,第二种配置后解决了 https://blog.csdn.net/sinat_32404247/article/details/90287700...

三三的宁
今天
18
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部