Spring Cloud Alibaba微服务从入门到进阶(七)(服务容错-Sentinel)
雪崩效应
我们把基础服务故障,导致上层服务故障,并且这个故障不断放大的过程,成为雪崩效应。
雪崩效应,往往是因为服务没有做好容错造成的。
微服务常见容错方案
仓壁模式
比如让controller有自己独立的线程池,线程池满了就直接拒绝请求
断路器模式
对api进行监控,设置一段时间内的错误率、错误次数。
如果一段时间内达到预值,断路器就会打开,不去调用远程api了。
(断路器模式设计了半开状态,远程api恢复后,断路器可以再次闭合。)
使用Sentinel实现容错
Sentinel是一个实现服务容错的库。
微服务整合sentinel
加依赖(无注解、无配置)
服务整合Sentinel后,通过actuator/sentinel可以访问到
搭建Sentinel控制台
登录,账户/密码 sentinel/sentinel

目前控制台上什么都没有,在服务配置上整合sentinel的控制台地址
调用服务后再刷新控制台,可以看到服务(sentinel和ribbon一样都是懒加载的)

用@SentinelResource注解,进行限流和降级

可以把block/fallback抽离出业务代码,定义单独类

RestTemplate整合Sentinel
使用@SentinelRestTemplate注解
将注解加在服务初始化类上,就可以给RestTemplate整合Sentinel了
写测试代码(就是使用feign之前的那段代码)
查看sentinel控制台->簇点电路
多出来的两行就是@SentinelRestTemplate注解支持的。
RestTemplate整合Sentinel还提供了一个开关resttemplate.sentinel.enabled
Feign整合Sentinel
只需要添加配置 feign.sentinel.enabled = true
Sentinel控制台结果和上面整合RestTemplate效果一下
如果服务被流控了,不想抛异常,
可以在UserCenterFeignClient接口@FeignClient注解上指定fallback参数到指定的类上
该类实现UserCenterFeignClient接口
配置sentinel流控规则,实现效果是“一个默认用户”,而不是抛异常了
Sentinel使用总结

相关文章:
Spring Cloud Alibaba微服务从入门到进阶(七)(服务容错-Sentinel)
雪崩效应 我们把基础服务故障,导致上层服务故障,并且这个故障不断放大的过程,成为雪崩效应。 雪崩效应,往往是因为服务没有做好容错造成的。 微服务常见容错方案 仓壁模式 比如让controller有自己独立的线程池,线程池满…...
Arduino RP2040 + SSD1306 I2C OLED +LittleFS存储GBK字库实现中文显示
Arduino RP2040 + SSD1306 I2C OLED +LittleFS存储GBK字库实现中文显示 📌LittleFS插件安装,可以参考《Arduino RP2040 LittleFS的使用介绍》🎈相关内容《Arduino esp8266 软件I2C SSD1306 +LittleFS存储GBK字库实现中文显示》🔖基于Earle F. Philhower, III的核心固件开…...
代码随想录算法训练营第day53|1143.最长公共子序列 、 1035.不相交的线、 53. 最大子序和 动态规划
目录 1143.最长公共子序列 1035.不相交的线 53. 最大子序和 1143.最长公共子序列 力扣题目链接(opens new window) 给定两个字符串 text1 和 text2,返回这两个字符串的最长公共子序列的长度。 一个字符串的 子序列 是指这样一个新的字符串:它是由原…...
【Flutter学习笔记】10.2 组合现有组件
参考资料: 《Flutter实战第二版》 10.2 组合现有组件 在Flutter中页面UI通常都是由一些低级别组件组合而成,当我们需要封装一些通用组件时,应该首先考虑是否可以通过组合其他组件来实现,如果可以,则应优先使用组合&…...
C++的vector类(一):vector类的常见操作
目录 前言 Vector类 遍历与初始化vector vector的扩容机制 vector的对象操作 find与insert 对象数组 前言 string类中还有一些内容需要注意: STL 的string类怎么啦? C面试中string类的一种正确写法 C STL string的Copy-On-Write技术 C的st…...
SpringBoot注解
Spring Boot 中常用的一些注解及其作用如下所示: SpringBootApplication:标注一个主程序类,用于启动 Spring Boot 应用,通常放在包的最顶层。 RestController:结合 Controller 和 ResponseBody,用于定义 R…...
每日三个JAVA经典面试题(十九)
1.Java Concurrency API 中的 Lock 接口(Lock interface)是什么?对比同步它有什么优势?Java并发API中的Lock接口提供了一种比传统synchronized块或方法更灵活、更强大的线程同步机制。Lock接口允许更细粒度的锁控制,通过它可以实现更复杂的线…...
springboot企业级抽奖项目业务一(登录模块)
开发流程 该业务基于rouyi生成好了mapper和service的代码,现在需要在controller层写接口 实际操作流程: 看接口文档一>controller里定义函数一>看给出的工具类一>补全controller里的函数一>运行测试 接口文档 在登录模块有登录和登出方…...
【Python + Django】启动简单的文本页面
前言: 为了应付(bushi)毕业论文,总要自己亲手搞一个像模像样的项目出来吧 ~ ~ 希望自己能在新的连载中学到项目搭建的知识,这也算是为自己的测试经历增添光彩吧!!! 希望、希望大家…...
Docker——问题解决:服务器端和Windows端IP互通
踩了大坑,特此记录!!!!! 我在服务器端部署了服务,但是在本地端Windows机器上无法访问,因此卡了一天。 1. 双向Ping通 防火墙导致只能单向Ping通 首先需要解决双向ping通的问题&…...
HTTP跨域
1. 简介 HTTP跨域是指不同域名下的网页请求资源时,由于浏览器同源策略限制,导致请求被阻止。为解决这一问题,开发者常采用跨域资源共享(CORS)等技术来允许合法跨域请求,确保网站功能正常运行。 同源 协议…...
用Python的turtle库绘制皮卡丘
turtle库的简介 turtle(海龟)库是turtle绘图体系的python实现,turtle库是一种标准库,是python自带的。 turtle(海龟)是一种真实的存在,有一个海龟在窗口的正中心,在画布上游走,走过的轨迹形成了绘制的图形࿰…...
C语言打印当前时间
#include <time.h> void print_current_time(char* func_name) { // 获取当前的时间 time_t current_time; time(¤t_time); // 将时间转换为本地时间格式 struct tm *local_time localtime(¤t_time); // 打印当前的时间 …...
(一)基于IDEA的JAVA基础4
注释文本,注释模版 单行注释://开头放在代码前面,对少部分。 多行注释:快捷方式ctrlshift/,对段落代码注 释。 文档注释:/**……**/,用于声明作者或创作时 间。 文档注释如何设置,首先找到File中…...
【Python】复习12:标准库与第三方库
目录 概念标准库第三方库总结Python 标准库`os` 模块`sys` 模块`json` 模块`re` 模块`datetime` 模块代码示例`os` 模块例子`sys` 模块例子`json` 模块例子`re` 模块例子`datetime` 模块例子第三方库`numpy``pandas``requests`安装第三方库使用第三方库其他一些流行的Python库数…...
CUDA 12介绍
CUDA(Compute Unified Device Architecture)是由 NVIDIA 开发的并行计算平台和应用程序编程接口(API)。CUDA 使开发人员能够使用 NVIDIA GPU 进行通用目的的并行计算。CUDA 通过利用 GPU 的大规模并行计算能力来加速各种类型的计算…...
旅游系统-软件与环境
运行 1.下载软件并进行环境配置 2.导入项目包以及SQL文件 (1)VsCode 管理员运行打开 a.新建terminal 注意: 1.执行 npm config set registry https://registry.npm.taobao.org 2.执行 npm install 3.执行 $env:NODE_OPTIONS“–openssl-legacy-provider” b.输入…...
AI基础知识(2)--决策树,神经网络
1.什么是决策树? 决策树是一类常见的机器学习方法,决策树是基于树的结构来进行决策。决策过程中提出的每一个问题都是对于属性的“测试”,决策的最终结论对应了我们希望的判定结果。一个决策树包含一个根节点,若干个内部节点和若…...
蓝桥杯C++大学B组一个月冲刺记录2024/3/21
蓝桥杯C大学B组一个月冲刺记录2024/3/20 规则:每日三题 今日的题很简单┗|`O′|┛ 嗷~~ 1.奶酪 现有一块大奶酪,它的高度为 h ,它的长度和宽度我们可以认为是无限大的,奶酪中间有许多半径相同的球形空洞。 我们可以在…...
由浅到深认识C语言(14):枚举
该文章Github地址:https://github.com/AntonyCheng/c-notes 在此介绍一下作者开源的SpringBoot项目初始化模板(Github仓库地址:https://github.com/AntonyCheng/spring-boot-init-template & CSDN文章地址:https://blog.csdn…...
手把手教你解决‘GLIBC_2.34‘ not found报错:从下载到编译的完整流程
深度解析GLIBC版本兼容性问题:从源码编译到环境隔离的全方位解决方案 当你兴致勃勃地准备运行某个新工具时,终端突然弹出"GLIBC_2.34 not found"的红色错误提示,这种挫败感想必很多Linux开发者都深有体会。GLIBC作为Linux系统的核心…...
基于机器视觉的苹果品质分级系统的设计与实现
前言 在对苹果品质进行分级时经常应用到的技术是机器视觉技术,此技术在当前的应用中已经逐渐成为最关键的检测方法之一。机器视觉技术由于受到图像处理技术的支持在苹果品质品质检测方面更加科学与专业,由此在以后的技术应用与发展中越来越有发展前途。 …...
RT-DETR实战入门:从零搭建PyTorch训练环境与数据准备
1. RT-DETR简介与环境配置 RT-DETR是百度最新推出的实时目标检测模型,基于Transformer架构设计,在速度和精度上都有不错的表现。相比传统的YOLO系列,RT-DETR采用了更先进的注意力机制,能够更好地处理复杂场景中的目标检测任务。对…...
YOLO12多尺度检测效果展示:同一图像不同分辨率输入结果对比图集
YOLO12多尺度检测效果展示:同一图像不同分辨率输入结果对比图集 1. 引言:为什么分辨率对目标检测如此重要? 想象一下,你用手机拍了一张远处的风景照,照片里有个很小的人影。当你把照片放大看时,这个人影可…...
STM32G474内部FLASH数据管理实战:从原理到IAP应用
1. STM32G474内部FLASH架构解析 STM32G474系列微控制器搭载了512KB容量的内部FLASH存储器,采用创新的双Bank设计架构。我第一次拿到芯片手册时,发现这个双Bank结构特别有意思——它把512KB空间平均分成两个256KB的Bank,每个Bank又细分为128个…...
STM32无刷电机开环控制实战:从CubeMX配置到SPWM波形生成全流程
STM32无刷电机开环控制实战:从CubeMX配置到SPWM波形生成全流程 在嵌入式开发领域,无刷电机控制一直是技术热点与难点。相比传统有刷电机,无刷电机凭借高效率、长寿命和低噪音等优势,在无人机、机器人、工业自动化等领域获得广泛应…...
刷手机刷到颈腰痛别不当回事,颈椎病腰间盘突出正在毁掉低头族,科学防护与诊疗指南来了!
如今,"低头族" 已成为随处可见的社会现象,无论是通勤路上、吃饭时还是睡前,人们都在低头刷手机。但很多人不知道,当你沉迷于短视频时,你的脊柱正在承受着巨大的伤害。医学研究表明,低头 60 时&am…...
育苗基质到底是什么?一文读懂现代农业育苗核心,附真实种植案例
在现代农业种植体系中,育苗是决定作物长势与产量的首要环节,而育苗基质作为幼苗生长的“土壤温床”,是很多种植户容易忽略却至关重要的农资产品。相较于传统田园土,专业育苗基质能为种子萌发、幼苗生长提供更稳定的环境࿰…...
Ubuntu动态库路径管理全攻略:从LD_LIBRARY_PATH到ldconfig实战
1. 动态库路径管理基础 当你第一次在Ubuntu上运行程序时,看到"error while loading shared libraries"这样的报错,是不是感觉一头雾水?这其实是Linux系统在告诉你:"我找不到程序需要的动态库文件啦!&q…...
第九篇、CubeMX | FreeModbus 主机移植实战:基于RT-Thread的事件驱动与FIFO队列优化
1. 环境准备与基础概念 在开始FreeModbus主机移植前,我们需要先理解几个关键概念。RT-Thread是一个嵌入式实时操作系统,而FreeModbus是一个开源的Modbus协议栈。Modbus协议广泛应用于工业自动化领域,分为主机(Master)和从机(Slave)两种模式。…...
