前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >springcloud原理详解_SpringMVC运行原理

springcloud原理详解_SpringMVC运行原理

作者头像
全栈程序员站长
发布2022-11-01 11:05:11
4260
发布2022-11-01 11:05:11
举报
文章被收录于专栏:全栈程序员必看

SpringCloud Eureka原理分析

一、Eureka的基础架构及服务治理机制

  Eureka服务治理的基础架构包含三个核心:服务注册中心、服务提供者、服务消费者。其中服务注册中心,即Eureka提供的服务端,提供服务注册和发现的功能;服务提供者,即将自己的服务注册到注册中心;服务的消费者,从注册中心获取服务列表,从而使消费者知道到何处调用服务,服务消费可以使用Ribbon、Feign等。

1、服务提供者:

  1. 服务注册:服务提供者在项目启动时,会通过发送REST请求的方式将自己注册到eureka server上,同时带上一些自己的元数据,Eureka Server收到请求后,将元数据存储在一个双层map中,第一层的key是服务名称,第二层的key是具体的服务实例。
  2. 服务同步:如果A项目将服务注册到了M注册中心,B项目将服务注册到N注册中心,但是如果M项目和N项目开启了可以注册为服务的配置,那么当A项目将服务注册到M注册中心时,M注册中心会将请求转发到N注册中心,以保证两个注册中心副本中服务同步。
  3. 服务续约:在注册完服务后,服务提供者会维护一个心跳(30s发送一次)来持续告诉注册中心其还活着,以防止注册中心的剔除任务将该服务实例从服务列表中删除。

关于心跳频率与剔除任务认为服务失效时间的配置参数如下所示(配置值均为默认值):

eureka:

instance:

# 心跳检测频率

lease-renewal-interval-in-seconds: 30

# 服务失效时间

lease-expiration-duration-in-seconds: 90

2、服务消费者:

  1. 获取服务:当启动服务消费者项目时,会向注册中心发送一个REST请求来获取注册中心上注册的服务清单。为了性能的考虑,注册中心自己维护了一份只读的注册服务清单,每30秒更新一次,要调整注册中心中注册服务清单更新频率,可以使用如下参数进行设置(下面示例为默认值),同时,由于获取服务是服务消费的基础,因此需要保证eureka.client.fetch-registry为true

eureka:

client:

registry-fetch-interval-seconds: 30

fetch-registry: true

  1. 服务调用:服务消费者在获取到服务提供清单后,会根据服务名获得具体的实例名和该实例的元数据,然后客户端可以根据自己需要,选择调用哪个实例,在上述代码样例中,我们使用的是Ribbon来做负载均衡,而ribbon默认采用轮询的方式进行调用,从而实现客户端的负载。对于访问实例的选择,Eureka中有Region和Zone的概念,一个Region中可以包含多个Zone,一个客户端会被注册到一个Zone中,所以一个客户端只对应一个Zone和一个Region,在服务调用时,优先访问处于同一个Zone中的服务提供者,若访问不到,再访问其他Zone中的服务提供者。
  2. 服务下线:当客户端实例进行正常的关闭操作时,它会触发一个服务下线的REST请求给注册中心,告诉注册中心其要下线,注册中心收到请求后,将该服务状态置为下线,并把该事件传播出去。

3、服务注册中心

  1. 失效剔除:有时服务实例并不会正常下线,可能是由于内存溢出、网络故障等原因使得服务不能正常运行,所以注册中心并未收到服务下线的请求。为了剔除该类不可用服务提供者实例,Eureka Server在启动时,会创建一个定时任务,每隔一段时间(默认60秒)将当前清单中超时(默认90秒)没有续约的服务剔除出去。
  2. 自我保护:前面提到过,服务提供者启动后,会维护一个心跳,定时向注册中心发送心跳,告诉注册中心自己还活着。注册中心的运行期间,会统计心跳失败的比例。在15分钟内是否低于85%,如果低于85%,注册中心会将该服务的实例保护起来,不让其过期,但是由于在本地测试,所以这个情况非常容易满足(而线上则主要是由于网络不稳定等导致),这就导致在保护期间内,如果服务提供者实例出现问题,那么客户端就会拿到有问题的实例,将会出现调用失败的情况,因此客户端必须要有容错机制,比如说请求重试、断路器等机制。如果我们想关闭自我保护机制,可以使用如下参数。

eureka:

server:

enable-self-preservation: false

二、Jersey (熟悉而又陌生的Contoller)

Springcloud是典型的Servlet应用,服务端与客户端之间通过Restful接口交互。

EurekaSever 与EurekaClient 之间也是跟我平时做系统之间交互差不多。我们写了这么多Controller,业务系统之间怎么通过接口交互,应该很明确了。

与我们熟悉的代码不同的是

我们用的是SpringMVC框架, 写的是Controller.

Eureka 用的是Jersey框架,Jersey框架里类Controller的组件叫做ApplicationResource概念。

接口包:

  • 我们通常定义一个 xxx.controller包 ,里面存放的就是我们的接口
  • Eureka有个resources包,里面存放的就是EurekaServer的对外的接口com.netflix.eureka.resources包。
springcloud原理详解_SpringMVC运行原理
springcloud原理详解_SpringMVC运行原理

接口: 接口有哪些呢?

从其wiki文档中,你会看到这样一个目录Eureka-REST-operations,

springcloud原理详解_SpringMVC运行原理
springcloud原理详解_SpringMVC运行原理

Google的guava框架(瓜娃子)

Eureka里用到的很多工具类,都是来自Google的guava项目。

列如:

缓存:Eureka里面使用了很多缓存都是使用Google的guava缓存构建的。

HTTP通信

EurekaSeverEurekaClient 之间的通信协议是HTTP.

我们常用的Resttemplate发起一个Post/GET请求。

EurekaClient 在与EurekaSever 通信时,用的是一个叫做EurekaTransport的HTTP工具。

EurekaServer的设计思想

  • 读写分离思想(缓存分级):当出现频繁的读与写时,此时想到的应该就是读写分离思想。EurekaSever也是这么做的
  • 定时刷新
  • 定时驱逐
  • STW

InstanceInfo域值(DTO)

EurekaSeverEurekaClient 之间的通信的基本单位是InstanceInfo

客户端组装一个代表自己的信息的InstanceInfo, 注册到EurekaSeverEurekaSever 将这个InstanceInfo缓存起来,

参考:

https://www.cnblogs.com/liconglong/p/13223182.html

https://www.lagou.com/lgeduarticle/131536.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/179376.html原文链接:https://javaforall.cn

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • SpringCloud Eureka原理分析
    • 一、Eureka的基础架构及服务治理机制
      • 1、服务提供者:
      • 2、服务消费者:
      • 3、服务注册中心
    • 二、Jersey (熟悉而又陌生的Contoller)
      • 接口包:
      • Google的guava框架(瓜娃子)
      • HTTP通信
      • EurekaServer的设计思想
      • InstanceInfo域值(DTO)
相关产品与服务
服务网格
服务网格(Tencent Cloud Mesh, TCM),一致、可靠、透明的云原生应用通信网络管控基础平台。全面兼容 Istio,集成腾讯云基础设施,提供全托管服务化的支撑能力保障网格生命周期管理。IaaS 组网与监控组件开箱即用,跨集群、异构应用一致发现管理加速云原生迁移。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档