微服务保护和分布式事务(Sentinel、Seata)笔记

一、雪崩问题的解决的服务保护技术了解

二、Sentinel

2.1Sentinel入门

1.Sentinel的安装

(1)下载Sentinel的tar安装包先
(2)将jar包放在任意非中文、不包含特殊字符的目录下,重命名为

sentinel-dashboard.jar

(3)在cmd窗口中使用启动命令
复制代码
java -Dserver.port=8090 -Dcsp.sentinel.dashboard.server=localhost:8090 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar

2.注入Sentinel依赖

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

3.application.yml中配置

复制代码
spring:
  cloud: 
    sentinel:
      transport:
        dashboard: localhost:8090

2.2 Sentinel请求限流

通过蔟点链路的流控,设置单点阈值,对请求进行限流

2.3 Sentinel线程隔离

在cart的apllication.yml中进行配置限制

2.4 Sentinel-Fallback

2.5 Sentinel熔断

三、分布式事务Seata

3.1认识Seata

3.2Seata的部署

下载tar包进行后加载镜像

复制代码
docker load -i seata.tar

查看镜像是否加载成功

复制代码
docker images

查看列出所有网络

复制代码
docker network ls

查看mysql的是否连接网络,使用查看mysql详细信息的命令

复制代码
docker inspect mysql

查看nacos的是否连接在同一网络

复制代码
docker inspect nacos

(如果不在则需要添加)例如将nacos加入网络中

复制代码
docker network connect hm-net nacos

需要在seata文件夹中根据实际情况在application.yml中修改Mysql的配置

部署命令(需要根据具体情况修改SEATA_IP为自己的虚拟机IP地址,network为所连接的网络)

复制代码
docker run --name seata \
-p 8099:8099 \
-p 7099:7099 \
-e SEATA_IP=192.168.92.136 \
-v ./seata:/seata-server/resources \
--privileged=true \
--network hm-net \
-d \
seataio/seata-server:1.5.2

3.3微服务整合Seata

相关推荐
.生产的驴11 分钟前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
猿周LV19 分钟前
JMeter 安装及使用 [软件测试工具]
java·测试工具·jmeter·单元测试·压力测试
晨集21 分钟前
Uni-App 多端电子合同开源项目介绍
java·spring boot·uni-app·电子合同
时间之城23 分钟前
笔记:记一次使用EasyExcel重写convertToExcelData方法无法读取@ExcelDictFormat注解的问题(已解决)
java·spring boot·笔记·spring·excel
椰羊~王小美30 分钟前
LeetCode -- Flora -- edit 2025-04-25
java·开发语言
灏瀚星空32 分钟前
用Obsidian四个插件打造小说故事关联管理系统:从模板到图谱的全流程实践
经验分享·笔记·开源
凯酱38 分钟前
MyBatis-Plus分页插件的使用
java·tomcat·mybatis
一只可爱的小猴子1 小时前
2022李宏毅老师机器学习课程笔记
人工智能·笔记·机器学习
程序员总部1 小时前
如何在IDEA中高效使用Test注解进行单元测试?
java·单元测试·intellij-idea
oioihoii1 小时前
C++23中if consteval / if not consteval (P1938R3) 详解
java·数据库·c++23