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

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

项目示例:

内容提要:

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

文档:

服务调用

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

负载均衡

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

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

服务调用框架

openfeign

降级熔断限流

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

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

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

降级熔断框架

Sentinel

网关

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

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

网关框架

Spring Cloud Gateway

相关推荐
李洋-蛟龙腾飞公司7 分钟前
HarmonyOS Next 应用元服务开发-分布式数据对象迁移数据文件资产迁移
分布式·华为·harmonyos
搬码后生仔41 分钟前
asp.net core webapi项目中 在生产环境中 进不去swagger
chrome·后端·asp.net
凡人的AI工具箱1 小时前
每天40分玩转Django:Django国际化
数据库·人工智能·后端·python·django·sqlite
Lx3521 小时前
Pandas数据重命名:列名与索引为标题
后端·python·pandas
小池先生2 小时前
springboot启动不了 因一个spring-boot-starter-web底下的tomcat-embed-core依赖丢失
java·spring boot·后端
科技互联人生2 小时前
微服务常用的中间件及其用途
微服务·中间件·系统架构
技术路上的苦行僧3 小时前
分布式专题(10)之ShardingSphere分库分表实战指南
分布式·shardingsphere·分库分表
小蜗牛慢慢爬行3 小时前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
GitCode官方3 小时前
GitCode 光引计划投稿 | GoIoT:开源分布式物联网开发平台
分布式·开源·gitcode
wm10434 小时前
java web springboot
java·spring boot·后端