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

相关推荐
C雨后彩虹36 分钟前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
tycooncool1 小时前
Spring中的IOC详解
java·后端·spring
一江寒逸1 小时前
零基础从入门到精通 AI Agent 开发(全栈保姆级教程)附加篇:AI Agent 面试八股文全集
人工智能·面试·职场和发展
爱敲代码的小黄1 小时前
我重新梳理了一遍 RAG,终于明白它不只是接个向量库
后端·面试·agent
久菜盒子工作室1 小时前
面试经验|产品经理|自我介绍
面试·职场和发展·产品经理
Ken_11152 小时前
SpringCloud系列(63)--Nacos读取不同配置之DataID配置方案
spring cloud
Ruihong2 小时前
Vue v-bind 转 React:VuReact 怎么处理?
vue.js·react.js·面试
优秀1353 小时前
计算机基础面试重点知识
网络·面试·职场和发展
木斯佳3 小时前
前端八股文面经大全:字节TikTok前端一面(2026-04-17)·面经深度解析
前端·面试·八股·面经
Wect4 小时前
深度解析浏览器本地存储:原理、方案与实战指南
前端·面试·浏览器