SpringCloud全家桶---常用微服务组件(1)

注册中心:

*作用: 服务管理

Eureka(不推荐)[读音: 优瑞卡]

Nacos(推荐)

Zookeeper [读音: 如k波]

Consul [读音:康寿]

复制代码
**注册中心的核心功能原理(nacos)**
服务注册: 当服务启动时,会通过rest接口请求的方式向Nacos注册自己的服务
服务心跳:  NacosClient 会维护一个定时心跳持续通知NacosServer,默认5秒一次,超过15秒,会将服务健康状态设置为false(拉去时会忽略),超过30秒会剔除
服务发现: nacosClient定时任务,实时去拉去健康服务
服务终止: NacosClient会主动通过Rest请求NacosService,

负载均衡:

* 作用: 客户端的负载均衡

ribbon [读音: 瑞本]

LodaBalancer(推荐)

服务调用

*作用: 能像调用本地方法一样优雅

Feign(不推荐)

OpenFeign(推荐)

Dubbo

配置中心

SpringCloud config

NacosConfig(推荐)

服务熔断:

*防止服务雪崩,防止流量激增打垮冷系统

Hystrix

sentinel(推荐) [读音: 申特闹 ]

分布式事务

Seata

复制代码
有四种模式: AT、TCC、SAGA 和XA 

Seata实现原理:
两个阶段,三个角色
TC: 事务协调者,独立运行seata-server,用于接受事务注册,提交和回滚
TM: 事务管理者(发起者),告诉TC全局事务提交回滚
RM: 事务资源,每一个RM都会作为一个分支事务注册在TC

AT模式: 
第一阶段: 
TM(事务发起者)向TC申请开启一个全局事务,事务创建并生成一个全局唯一的XID
XID在微服务调用链路的上下文中传播
① seata会拦截"业务sql",解析sql语句
②查询 "业务SQL" 要更新的业务数据,在业务数据被更新前,将其保存成 "before image"
③执行 "业务SQL" ,更新业务数据
④查询更新后的数据,将其保存成 "after image"
⑤将 before image 和 after image 保存至 Undo Log 表中
生成行锁
以上操作全部在一个数据库事务内完成,这样保证了一阶段操作的原子性。
提交前RM(事务资源)会向TC(事务协调者)注册分支;
TM(事务发起者)向TC(事务协调者)发起针对XID的全局提交或回滚,将本地事务提交结果上报给TC

第二阶段:
提交:   因为 "业务SQL" 在一阶段已经提交至数据库,所以 Seata 框架只需将一阶段保存的快照数据(Undo Log )和行锁删掉,完成数据清理即可。
回滚:   校验当前数据和 after image 数据,数据一致说明没脏写,可以还原数据,脏写了就要转人工处理;
用before image 还原数据,删除undolog数据和行锁

服务网关

*作用: 一些本身跟业务无关的公共逻辑,鉴权,日志,限流,跨域

zuul

SpringCloudGateway(推荐)

linkred

Kong

复制代码
业务网关: 降级/熔断,负载均衡,鉴权,业务规则,参数校验
流量网关:  安全策略,流量分发,跨域实现

链路追踪

*作用: 追踪服务健康状况

Skywalking(推荐)

Zipkin

相关推荐
ChinaRainbowSea4 分钟前
9. LangChain4j + 整合 Spring Boot
java·人工智能·spring boot·后端·spring·langchain·ai编程
在未来等你16 分钟前
Kafka面试精讲 Day 18:磁盘IO与网络优化
大数据·分布式·面试·kafka·消息队列
程序员清风29 分钟前
滴滴三面:ZGC垃圾收集器了解吗?
java·后端·面试
南北是北北1 小时前
Flow中的背压与并发
面试
洋楼街的奇妙圆子1 小时前
学术论文检索聚合 MCP 服务
面试·mcp
muchan921 小时前
为什么“它”在业务逻辑上是最简单的?
前端·后端·面试
虫小宝2 小时前
返利app排行榜的缓存更新策略:基于过期时间与主动更新的混合方案
java·spring·缓存
zzywxc7872 小时前
AI工具全景洞察:从智能编码到模型训练的全链路剖析
人工智能·spring·ios·prompt·ai编程
沐浴露z10 小时前
【Java SpringAI智能体开发学习 | 2】SpringAI 实用特性:自定义Advisor,结构化输出,对话记忆持久化,prompt模板,多模态
java·spring·springai
不要再敲了11 小时前
JDBC从入门到面试:全面掌握Java数据库连接技术
java·数据库·面试