IT自学第四十四天(微服务安全与分布式事务)

微服务


服务保护

分布式事务

1、微服务雪崩问题

微服务的问题分析

商品管理挂机了,导致其他业务也挂机。

雪崩问题;Sentinel;分布式事务

雪崩问题

微服务调用链路中的某个服务故障,引起整个链路中的所有微服务都不可用,这就是雪崩。

解决思路:服务调用者做好远程调用异常的后备方案,避免异常扩散。

2、服务保护方案

服务保护方案-请求限流

请求限流:限制访问接口的请求的并发量,避免服务因流量激增出现故障。

服务保护方案-线程隔离

线程隔离:也叫做舱壁隔离,模拟船舱隔板的防水原理。通过限定每个业务能使用的线程数量而将故障业务隔离,避免故障扩散。

服务保护方案-服务熔断

服务熔断:由断路器统计请求的异常比例或慢调用比例,如果超出阈值则会熔断该业务,则拦截该接口的请求。

熔断期间,所有请求快速失败,全部走fallback逻辑。

失败处理:定义fallback逻辑,让业务失败时不再抛出异常,而是走fallback逻辑。

3、服务保护技术

服务保护技术

4、安装sentinel

初识Sentinel

Sentinel是阿里巴巴开源的一款微服务流量控制组件。官网地址:https://sentinelguard.io/zh-cn/index.html

安装Sentinal

注意:保持Java环境。

5、微服务整合sentinel

cart-service整合Sentinel

引入依赖:

XML 复制代码
<!--        sentinel-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>

代码演示:

XML 复制代码
    sentinel:
      transport:
        dashboard: localhost:8090

6、簇点链路

Restful风格的API请求路径一般都相同,这会导致簇点资源名称重复。因此我们要修改配置,把请求方式+请求路径作为簇点资源名称:

代码演示:

XML 复制代码
    sentinel:
      transport:
        dashboard: localhost:8090
      http-method-specify: true # 开启资源方法前缀

7、请求限流

请求限流

在簇点链路后面点击流控按钮,即可对其做限流配置:

QPS:平均一秒内的访问数量;

7.1、请求限流-补充版

同上

8、线程隔离

线程隔离

当商品服务出现阻塞或故障时,调用商品服务的购物车服务可能因此而被拖慢,甚至资源耗尽。所以必须限制购物车服务中查询商品这个业务的可用线程数,实现线程隔离。

首先让OpenFeign整合Sentinel:

在sentinel控制台中,会出现Feign接口的簇点资源,点击后面的流控按钮,即可配置线程隔离:

9、fallback远程调用客户端异常处理

10、服务熔断

11、分布式事务

分布式事务

下单业务,前端请求首先进入订单服务,创建订单并写入数据库。然后订单服务调用购物车服务和库存服务:

  • 购物车服务负责清理购物车信息
  • 库存服务负责扣减商品库存

在分布式系统中,如果一个业务需要多个服务合作完成,而且每一个服务都有事务,多个事务必须同时成功或失败,这样的事务就是分布式事务。其中的每个服务的事务就是一个分支事务。整个业务称为全局事务。

12、初始Seata

初始Seata

分布式事务解决思路

Seata架构

Seata事务管理中有三个重要的角色:

13、部署Seata

准备数据库表

准备配置文件

Docker部署:将seata上传到root文件夹

nacos中要有seata-server服务。

14、微服务集成Seata

首先,要在项目中引入Seata依赖:

然后,在application.yml中添加配置,让微服务找到TC服务地址:

案例:微服务集成Seata

需求:将Seata配置共享到nacos中,避免重复配置;并解决商品下单中发生的分布式事务问题。

15、Seata-强一致性事务模式XA

16、Seata-最终一致性事务模式AT

相关推荐
薛定猫AI1 小时前
Codex 与 Claude Code 安装配置完全指南
大数据·人工智能·架构
GISer_Jing2 小时前
Claude Code插件系统全解析
前端·人工智能·ai·架构
KaMeidebaby2 小时前
卡梅德生物技术快报|peg 修饰调控 MXene/WS2 异质结,氨气传感器制备与机理研究
大数据·前端·人工智能·架构·spark·新浪微博
陈陈CHENCHEN2 小时前
【Kubernetes】Kubeadm 搭建生产级 K8s 高可用集群
云原生·容器·kubernetes
龙佚2 小时前
抖动缓冲与播放控制:平滑播放的艺术
前端·架构
X54先生(人文科技)3 小时前
《元创力》纪实录·卷宗2.1刻舟求剑:一场关于“唯一解”的范式战争
人工智能·架构·开源·零知识证明
@insist1233 小时前
系统架构设计师-软件质量属性战术与架构评估方法全解
架构·系统架构·软考·系统架构设计师·软件水平考试
@insist1233 小时前
系统架构设计师-五大经典软件架构风格详解与软考真题应用指南
架构·系统架构·软考·系统架构设计师·软件水平考试
数据库小学妹4 小时前
InnoDB内存架构解密:Buffer Pool与性能优化实战
数据库·经验分享·sql·性能优化·架构
GISer_Jing4 小时前
Claude Code MCP Server 集成全解析
前端·人工智能·ai·架构