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

相关推荐
天若有情6737 分钟前
【java EE】IDEA 中创建或迁移 Spring 或 Java EE 项目的核心步骤和注意事项
后端·spring·java-ee·intellij-idea
钱多多_qdd2 小时前
基础篇:IoC(三):Bean实例化策略InstantiationStrategy
java·spring
007php0075 小时前
某游戏互联网大厂Java面试深度解析:Java基础与性能优化(一)
java·数据库·面试·职场和发展·性能优化·golang·php
狂炫冰美式5 小时前
QuizPort 1.0 · 让每篇好文都有测验陪跑
前端·后端·面试
安冬的码畜日常5 小时前
【JUnit实战3_27】第十六章:用 JUnit 测试 Spring 应用:通过实战案例深入理解 IoC 原理
spring·观察者模式·设计模式·单元测试·ioc·依赖注入·junit5
沐怡旸6 小时前
【底层机制】垃圾回收(GC)底层原理深度解析
android·面试
Moonbit6 小时前
MoonBit Pearls Vol.12:初探 MoonBit 中的 Javascript 交互
javascript·后端·面试
沐怡旸6 小时前
【穿越Effective C++】条款13:以对象管理资源——RAII原则的基石
c++·面试
敲代码的嘎仔7 小时前
JavaWeb零基础学习Day6——JDBC
java·开发语言·sql·学习·spring·单元测试·maven
T___T7 小时前
彻底搞懂 CSS 盒子模型 box-sizing:小白也能看懂的布局核心
前端·面试