spring cloud微服务常用组件

组件介绍

  • Nacos ​:在微服务架构中,每个服务可能是集群部署在多台服务器上,并且由于扩容或者是迁移IP是动态变化的,这样不方便管理,也不便于微服务间的通信。因此需要有一个独立的中心平台,对所有的微服务进行统一管理。nacos便是充当这个角色的,提供服务注册发现 ,让服务找到彼此;集中管理配置,使动态调整无需重启。

  • OpenFeign ​:微服务之间的通信中同步方案通常通过RESTful风格的HTTP API实现。而传统方式使用RestTemplate 这种编程式实现需要自己拼接请求路径比较麻烦,而OpenFeign可以理解为是一种更高阶抽象的声明式的服务调用RPC框架 ,提高了开发效率的同时还提升了系统的可维护性。无缝集成spring-cloud-starter-loadbalancer实现负载均衡

  • Sentinel ​:微服务之间相互依赖,一个服务的不可用(如处理缓慢或者异常)可能沿着调用链蔓延,导致整个系统崩溃。sentinel以流量 为切入点,实现流量控制熔断降级系统保护,保障服务的稳定性和高可用。

  • Gateway ​:微服务架构下,应用被拆分为数十甚至上百个服务。如果让客户端直接面对这么多细粒度的服务,会存在认证、鉴权、日志、流量控制等公共逻辑重复实现 、难以管理的问题。需要一个统一的流量入口,作为所有请求的"门卫"和"路由",统一处理非业务功能。

  • Seata ​:在单体应用拆分为微服务后,一个业务操作需要跨多个服务、多个数据库。此时,单个数据库的ACID事务无法保障业务数据的全局一致性。需要一个外部的组件来协调多个本地事务,要么全部成功,要么全部回滚,这就是分布式事务问题,Seata就是为此而生。

相关推荐
JavaBoy_XJ几秒前
结构型-组合模式
spring·组合模式
@淡 定6 分钟前
缓存原理详解
java·spring·缓存
就叫飞六吧11 分钟前
基于spring web实现简单分片上传demo
java·前端·spring
我就是你毛毛哥15 分钟前
微服务的拆分原则
微服务·云原生·架构
我就是你毛毛哥17 分钟前
微服务的注册中心
微服务·云原生·架构
程序猿零零漆28 分钟前
Spring之旅 - 记录学习 Spring 框架的过程和经验(三)Bean的依赖注入配置、Spring的其它配置标签
java·学习·spring
赵榕1 小时前
RabbitMQ发布订阅模式多实例消费者防止重复消费实现方式
微服务·消息队列·rabbitmq
程序猿零零漆1 小时前
Spring之旅 - 记录学习 Spring 框架的过程和经验(二)基于Xml方式Bean的配置
xml·spring
刘个Java1 小时前
手搓遥控器通过上云api执行航线
java·redis·spring cloud·docker
东东的脑洞1 小时前
【面试突击】Spring Security + OAuth2 密码模式实战:Gateway 作为网关与资源服务器,Auth 作为认证服务器(完整认证链路解析)
spring·面试·gateway