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

相关推荐
2601_957780841 小时前
Agent记忆系统架构设计与工程实践:从短期暂存到长期持久化
大数据·网络·人工智能·架构·agent
米高梅狮子1 小时前
14.K8s 中部署 LNMP 架构 ECShop 电商
云原生·容器·架构·kubernetes·自动化
声网1 小时前
OpenAI 的 WebRTC 秘密架构:没有 SFU?没有问题!丨 Voice Agent 学习笔记
学习·架构·webrtc
sbjdhjd1 小时前
Docker 安全优化实战手册(企业级硬核版)
linux·运维·docker·云原生·容器·eureka·kubernetes
dd_669961 小时前
从纸质台账到数智中台:合同管理系统的技术演进与架构升级
架构
heimeiyingwang1 小时前
【架构实战】分布式事务Seata-AT:解决跨服务数据一致性的终极方案
分布式·架构
小短腿的代码世界1 小时前
Qt SSH2 深度解析:安全远程通信架构与源码级实现
qt·安全·架构
lvrongbao1 小时前
互联网大厂Java面试场景:从Spring到Redis的技术问答解析
java·redis·spring·微服务·分布式事务
9命怪猫2 小时前
[K8S小白问题集] - runtime是不是类似Ghost装机后OS的运行
云原生·容器·kubernetes