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

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

项目示例:

内容提要:

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

文档:

服务调用

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

负载均衡

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

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

服务调用框架

openfeign

降级熔断限流

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

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

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

降级熔断框架

Sentinel

网关

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

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

网关框架

Spring Cloud Gateway

相关推荐
上进小菜猪11 小时前
基于 YOLOv8 的昆虫智能识别工程实践 [目标检测完整源码]
后端
superman超哥11 小时前
Rust 异步递归的解决方案
开发语言·后端·rust·编程语言·rust异步递归
开心就好202512 小时前
iOS Crash日志全面解析:结构、类型与分析方法
后端
毕设源码-钟学长12 小时前
【开题答辩全过程】以 基于Spring Boot的社区养老服务管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
nbsaas-boot12 小时前
slice / map 在 Go GC 与内存碎片上的真实成本
开发语言·后端·golang
数据小馒头12 小时前
拒绝循环写库:MySQL 批量插入、Upsert 与跨表更新的高效写法
后端
子洋12 小时前
基于远程开发的大型前端项目实践
运维·前端·后端
indexsunny12 小时前
互联网大厂Java面试实战:微服务、Spring Boot与Kafka在电商场景中的应用
java·spring boot·微服务·面试·kafka·电商
yumgpkpm12 小时前
Cloudera CDH、CDP、Hadoop大数据+决策模型及其案例
大数据·hive·hadoop·分布式·spark·kafka·cloudera
sheji341612 小时前
【开题答辩全过程】以 基于spring boot的停车管理系统为例,包含答辩的问题和答案
java·spring boot·后端