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

相关推荐
晴殇i10 分钟前
【拿来就用】Uniapp路由守卫终极方案:1个文件搞定全站权限控制,老板看了都点赞!
前端·javascript·面试
简烦25 分钟前
外层事务的 afterCommit 中调用内层事务方法时,内层事务的 TransactionSynchronization 注册失败 / 不执行
java·spring
爱吃烤鸡翅的酸菜鱼32 分钟前
Spring Boot 注解全栈指南:涵盖 Bean 注册、配置加载、请求映射、事务控制、数据校验等一网打尽
java·开发语言·spring boot·后端·spring
running up36 分钟前
Spring IOC与DI核心注解速查表
java·后端·spring
YDS82937 分钟前
SpringCloud —— Sentinel详解
java·spring cloud·sentinel
JHC00000039 分钟前
119. 杨辉三角 II
python·算法·面试
LYFlied1 小时前
【每日算法】LeetCode 22. 括号生成
数据结构·算法·leetcode·面试·职场和发展
后端小张1 小时前
【JAVA 进阶】深入理解Sentinel:分布式系统的流量守卫者
java·开发语言·spring boot·后端·spring·spring cloud·sentinel
running up2 小时前
Spring-AOP与代理模式
java·spring·代理模式
2024暴富2 小时前
SpringBoot基于Mybatis拦截器实现数据权限(图文)
spring boot·spring cloud·mybatis