谷粒商城实战(033 业务-秒杀功能4-高并发问题解决方案sentinel 1)

Java项目《谷粒商城》架构师级Java项目实战,对标阿里P6-P7,全网最强

总时长 104:45:00 共408P

此文章包含第326p-第p331的内容


关注的问题

sentinel(哨兵)

sentinel来实现熔断、降级、限流等操作

腾讯开源的tendis,分布式缓存

第一辆车开太慢就会堵车

有的解释,降级是提供错误的一个兜底反馈,跟这个解释好像不太一样

sentinel学习

五种方法 我们一般使用第四种注解方法 第一种适配方法 第二种抛异常方法



步骤
  1. 引入sentinel包

    控制台

    查看调用的是哪个版本的sentinel

这个jar包是个springboot项目 可以java -jar 直接启动

这个项目默认端口是8080 如果被占用的话 可以用 --server.port=你要的端口号

步骤


控制台操作方式

新增一个流控规则

再次刷新 进行限流

出现空指针异常 加一下判断即可

只要加了依赖 就都会被监控

暴露规则

全部暴露

添加审计图

导入endpoint依赖就可以使用统计图

exclude是排除哪些(不暴露)

include(暴露)

自定义流控返回

新增一个配置类

sentinel 提供的管理器类

如果用spring5的webFlux编程就用下面的 这里我们用上面的

定义一个错误码

乱码了 我们定义一下编码就行


全服务引入

每个服务都导入actuator 然后配置信息


错误

循环依赖错误

这里是用构造注入的方式解决循环依赖

解决:

注掉@postConstruct (它的作用是 方法会在bean实例化后被立即调用。)

这里解决失败,还是报错,我们自己创建一个rabbitTemplate

这里的@Primary注解的作用: 用于指示一个类、方法或字段作为首选的候选对象。当应用于类时,@Primary注解表示该类是首选的候选对象,将优先被实例化。当应用于方法时,@Primary注解表示该方法是最优选的候选方法,将优先被调用。当应用于字段时,@Primary注解表示该字段是最优选的候选字段,将优先被访问。

我们定义的rabbitTemplate比别人的少一些配置 如下

还有一直解决方法

把@Bean注释的转换器和RabbitTemplate拆成两个文件,可以解决循环依赖


效果

走完流程后

流控效果
warm up(热身)


峰值如果是500 我们使用 warm up(热身) :10秒内放进来500个请求

排队等待

如果峰值时是500 进来700个请求 我们先将前500进行处理 然后剩下的200 等待我们设置的如3000毫秒 如果3000毫秒得不到处理 就抛出失败


相关推荐
神的孩子都在歌唱6 分钟前
3423. 循环数组中相邻元素的最大差值 — day97
java·数据结构·算法
Code季风18 分钟前
微服务分布式配置中心:Gin Web 服务层与 gRPC 服务层集成 Nacos 实战
分布式·微服务·rpc·架构·go·gin·consul
喜欢吃豆38 分钟前
深入企业内部的MCP知识(三):FastMCP工具转换(Tool Transformation)全解析:从适配到增强的工具进化指南
java·前端·人工智能·大模型·github·mcp
用户15517339388342 分钟前
前后端处理 `multipart/form-data` 混合参数(实体对象+文件)方案
java
东阳马生架构1 小时前
订单初版—3.支付和履约链路中的技术问题说明文档
java
paopaokaka_luck1 小时前
智能推荐社交分享小程序(websocket即时通讯、协同过滤算法、时间衰减因子模型、热度得分算法)
数据库·vue.js·spring boot·后端·websocket·小程序
留不住丨晚霞1 小时前
说说SpringBoot常用的注解?
java·开发语言
华科云商xiao徐1 小时前
Java多线程爬虫动态线程管理实现
java·爬虫·数据挖掘
柒七爱吃麻辣烫2 小时前
八股文系列-----SpringBoot自动配置的流程
java·spring boot·rpc
M1A12 小时前
Java 面试系列第一弹:基础问题大盘点
java·后端·mysql