分布式微服务 - 3.服务调用 - 1.概念

分布式微服务 - 3.服务调用 - 1.概念

项目示例:

内容提要:

  • 服务调用、负载均衡、框架
  • 降级熔断限流、框架
  • 网关、框架

文档:

服务调用

服务调用时,需要先获取服务消费者的ip和端口号等信息。因此,一般服务消费者进行服务调用前,需要有服务提供者先去服务注册中心进行服务注册,然后服务消费者再结合服务注册中心获取服务列表,进行服务调用。

负载均衡

服务提供者是一个集群时,服务调用时需要从集群中选择一个节点使用服务,负载均衡策略决定如何从集群中选择一个节点。

负载均衡分为服务端负载均衡和客户端负载均衡。服务端负载均衡是在集群前面加一层负载均衡工具(如Nginx),所有到集群的请求都统一向该负载均衡工具请求,然后由负载均衡工具根据策略转发到集群中的一个节点。客户端负载均衡是由请求端持有集群中所有节点的信息,然后根据本身的负载均衡策略选择一个节点发送请求。

服务调用框架

openfeign

降级熔断限流

分布式系统随着开发会逐渐变得庞大和复杂,用户的一次请求可能会触发一条复杂且较长的服务调用链条,一旦链条上某个微服务节点出现超时、异常等问题时,会导致整体服务失败、故障蔓延、长时间等待、无效占用资源等状况,降低系统弹性。

因此,针对一个服务提供者进行服务调用时,需要考虑服务提供者超时或故障情况下,能否返回一个备用方案来避免故障扩散(即服务降级),而且如何避免后续请求继续发送到该故障的微服务上(即服务熔断)。除此之外,还要考虑在访问流量骤增时,限制流量以防服务器瞬间崩溃。

服务降级熔断的实现一般是在服务提供者端,减少若干服务消费者端重复实现上的冗余,且能在服务提供者端进行统一配置。

降级熔断框架

Sentinel

网关

应用系统服务端(后端)被拆分成若干微服务后,每个微服务都有自己的IP地址、端口号、路径,渠道端应用访问API时没有统一的地址信息,因此需要在所有微服务(也可以包括其他资源)之前添加一个工具,所有外部请求统一要经过这个工具(系统对外唯一的入口),这也就是网关的路由功能。

除了路由功能外,还可以借助网关实现认证授权、参数校验、请求转换、监控等过滤器功能。

网关框架

Spring Cloud Gateway

相关推荐
计算机毕设VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue在线考试系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Tony Bai5 小时前
Go 的 AI 时代宣言:我们如何用“老”原则,解决“新”问题?
开发语言·人工智能·后端·golang
用户47949283569156 小时前
性能提升 40 倍!实战 PostgreSQL FDW 解决微服务跨库查询难题
数据库·后端
Blossom.1186 小时前
Prompt工程与思维链优化实战:从零构建动态Few-Shot与CoT推理引擎
人工智能·分布式·python·智能手机·django·prompt·边缘计算
计算机毕设VX:Fegn08956 小时前
计算机毕业设计|基于springboot + vue宠物医院管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Victor3567 小时前
Hibernate(9)什么是Hibernate的Transaction?
后端
Victor3567 小时前
Hibernate(10)Hibernate的查询语言(HQL)是什么?
后端
苏三说技术8 小时前
SpringSecurity、shiro 和 sa-token,到底选哪个?
后端
qq_2704900968 小时前
SpringBoot药品管理系统设计实现
java·spring boot·后端