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

news2024/10/5 22:23:26

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毫秒得不到处理 就抛出失败

在这里插入图片描述在这里插入图片描述


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1798653.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[已解决] Android手机如何通过Wi-Fi连接电脑?

在当前的数字化时代,Android和PC之间的文件传输需求日益增长。如果您正在寻找一种无需USB线即可将Android手机连接到PC的方法,那么您来对地方了。本文将向您介绍6种实用的方法,让您轻松通过Wi-Fi将Android手机连接到PC。 方式1:通…

什么是输入偏置电流?

输入偏置电流(input bias current):运放同相与反相端流入和流出的电流。理想的运放同相和反相端的阻抗是无穷大的,所以是无法流进和流出电流。 第一种定义:同相与反相端电流和的平均值 以AD8031运放举例,…

DVWA-XSS(Reflected)

反射型XSS可以用来窃取cookie Low 输入1111进行测试&#xff0c;发现1111被打印 输入<script>alert(document.cookie)</script>&#xff0c;出现弹窗&#xff0c;获得cookie Medium 查看后端代码&#xff0c;发现对<script>进行了转义&#xff0c;但是…

docker部署fastdfs

我的镜像包地址 链接&#xff1a;https://pan.baidu.com/s/1j5E5O1xdyQVfJhsOevXvYg?pwdhcav 提取码&#xff1a;hcav docker load -i gofast.tar.gz拉取gofast docker pull sjqzhang/go-fastdfs启动gofast docker run -d --name fastdfs -p 8080:8080 -v /opt/lijia/lijia…

MyBatis总结(1)- 初探

初次学习应该冒出来的几个问题点&#xff1a; 1. 是什么&#xff1f; 一款ORM框架&#xff08;对象关系映射&#xff0c;用来作为连接数据库的桥梁&#xff09;&#xff1b;Mybatis通过定义配置(mybatis-config)&#xff0c;映射&#xff08;mapper&#xff09;关系&#xff…

Vulnhub-DC-4

靶机IP:192.168.20.138 kaliIP:192.168.20.128 网络有问题的可以看下搭建Vulnhub靶机网络问题(获取不到IP) 信息收集 nmap扫下端口及版本 dirsearch扫下目录 没发现什么敏感信息&#xff0c;看下前端界面 想到会不会存在SQL注入&#xff0c;弱密码等漏洞。 经过测试SQL注入…

使用紫铜管制作半波天线的折合振子

一、概述 半波天线是一种简单而有效的天线类型&#xff0c;其长度约为工作波长的一半。它具有较好的辐射特性和较高的增益&#xff0c;广泛应用于业余无线电、电视接收等领域。使用紫铜管制作折合振子&#xff0c;不仅可以提高天线的机械强度&#xff0c;还能增强其导电性能。 …

实现开源可商用的 ChatPDF RAG:密集向量检索(R)+上下文学习(AG)

实现 ChatPDF & RAG&#xff1a;密集向量检索&#xff08;R&#xff09;上下文学习&#xff08;AG&#xff09; RAG 是啥&#xff1f;实现 ChatPDF怎么优化 RAG&#xff1f; RAG 是啥&#xff1f; RAG 是检索增强生成的缩写&#xff0c;是一种结合了信息检索技术与语言生成…

【C++软件调试技术】什么是pdb文件?如何使用pdb文件?哪些工具需要使用pdb文件?

目录 1、什么是pdb文件? 2、如何配置生成pdb文件? 3、pdb文件的时间戳和文件名称 3.1、pdb文件的时间戳 3.2、pdb文件的文件名称 4、有pdb文件才能在Visual Studio中调试代码 5、在Windbg中使用pdb文件 5.1、使用lm命令查看二进制文件的时间戳,去查找对应版本的pdb文…

k8s——secret配置资源管理

一、Secret 1.1 Secret定义 Secret是用来保存密码、token、密钥等敏感数据的k8s资源&#xff0c;这类数据虽然也可以存放在Pod或者镜像中&#xff0c;但是放在Secret中是为了更方便的控制如何使用数据&#xff0c;并减少暴露的风险。 1.2 Secret类型 kubernetes.io/service-ac…

优思学院|精益生产学习过程中如何提高自己的能力水平?

精益生产是一项实践多过理论的课题。 优思学院认为实践并不限于实际的工作&#xff0c;日常的思考同样重要&#xff0c;例如我们会要求学员在学习时不断思考各种事物&#xff0c;不限于自己的企业。例如当你去到一家餐厅&#xff0c;你能夠观察到什么浪费&#xff1f;你可否把…

JVM 虚拟机

JVM 是 Java Virtual Machine 的简称&#xff0c;意为 Java 虚拟机&#xff0c;虚拟机是指通过软件模拟的具有完整硬件功能的、运行在一个完全隔离的环境中的完整计算机系统。 常见的虚拟机有&#xff1a;JVM、VMwave、Virtual Box等。JVM 是一台被定制过的现实当中不存在的计算…

【全开源】防伪溯源一体化管理系统源码(FastAdmin+ThinkPHP+Uniapp)

&#x1f50d;防伪溯源一体化管理系统&#xff1a;守护品质&#xff0c;追溯无忧 一款基于FastAdminThinkPHP和Uniapp进行开发的多平台&#xff08;微信小程序、H5网页&#xff09;溯源、防伪、管理一体化独立系统&#xff0c;拥有强大的防伪码和溯源码双码生成功能&#xff0…

EXCEL多sheet添加目录跳转

EXCEL多sheet添加目录跳转 背景 excel中有几十个sheet&#xff0c;点下方左右切换sheet太耗时&#xff0c;希望可以有根据sheet名超链接跳转相应sheet&#xff0c;处理完后再跳回原sheet。 方案一 新建目录sheet&#xff0c;在A1写sheet名&#xff0c;右键选择最下方超链接…

usock: No such file or directory

在搭建T113的tina系统时&#xff0c;运行ubusd报错&#xff0c;“usock: No such file or directory” rootTinaLinux:/# ifup -a Failed to connect to ubus /sbin/ifup: line 51: /sbin/wifi: not foundrootTinaLinux:/# ubusd usock: No such file or directory因为运行 ubu…

正确的功能可将热晶体管风速计线性化

处理传感器电路输出信号的电路或计算公式必须生成传感器响应的反函数。例如&#xff0c;如果传感器响应是对数函数&#xff0c;则线性化部分的响应必须是指数的。 这项工作首先获取传感器响应的 46 个离散点&#xff08;参见参考论文中的图 4&#xff09;。刚开始时&#xff0…

MySQL-Explain使用

MySQL-Explain使用 type列 type列 这一列表示关联类型或访问类型&#xff0c;即MySQL决定如何查找表中的行&#xff0c;查找数据行记录的大概范围。 依次从最优到最差分别为&#xff1a;system > const > eq_ref > ref > range > index > ALL 一般来说&…

git 提交

当你不小心在master上改了代码&#xff0c;并且add&#xff0c; commit 之后&#xff0c;想push&#xff0c;发现根本push不了&#xff08;本来也不能直接将master代码push到远端&#xff09;&#xff0c;而且每次pull远程master的时候都要和本地的master进行merge &#xff0c…

初级软件测试快速入门

文章目录 初级软件测试-测试用例、缺陷报告的认识与使用软件测试简介测试分类模型质量模型测试模型 用例编写的八大要素用例设计方法缺陷 初级软件测试-测试用例、缺陷报告的认识与使用 软件测试简介 什么是软件测试&#xff1f; 使用技术手段验证软件是否满足需求 主流技能 …

【Linux】系统优化:一键切换软件源与安装Docker

引言 在Linux系统安装完成后&#xff0c;进行一些必要的初始化设置是提升系统性能和用户体验的关键。本文将重点介绍两个实用的一键脚本&#xff1a;LinuxMirrors提供的软件源切换脚本和Docker安装脚本。这两个脚本将帮助我们简化配置安装过程。 一键切换软件源脚本 在Linux…