当前位置: 首页 > news >正文

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(海龟)是一种真实的存在,有一个海龟在窗口的正中心,在画布上游走,走过的轨迹形成了绘制的图形&#xff0…...

C语言打印当前时间

#include <time.h> void print_current_time(char* func_name) { // 获取当前的时间 time_t current_time; time(&current_time); // 将时间转换为本地时间格式 struct tm *local_time localtime(&current_time); // 打印当前的时间 …...

(一)基于IDEA的JAVA基础4

注释文本&#xff0c;注释模版 单行注释://开头放在代码前面&#xff0c;对少部分。 多行注释:快捷方式ctrlshift/,对段落代码注 释。 文档注释:/**……**/&#xff0c;用于声明作者或创作时 间。 文档注释如何设置&#xff0c;首先找到File中…...

【Python】复习12:标准库与第三方库

目录 概念标准库第三方库总结Python 标准库`os` 模块`sys` 模块`json` 模块`re` 模块`datetime` 模块代码示例`os` 模块例子`sys` 模块例子`json` 模块例子`re` 模块例子`datetime` 模块例子第三方库`numpy``pandas``requests`安装第三方库使用第三方库其他一些流行的Python库数…...

CUDA 12介绍

CUDA&#xff08;Compute Unified Device Architecture&#xff09;是由 NVIDIA 开发的并行计算平台和应用程序编程接口&#xff08;API&#xff09;。CUDA 使开发人员能够使用 NVIDIA GPU 进行通用目的的并行计算。CUDA 通过利用 GPU 的大规模并行计算能力来加速各种类型的计算…...

旅游系统-软件与环境

运行 1.下载软件并进行环境配置 2.导入项目包以及SQL文件 (1)VsCode 管理员运行打开 a.新建terminal 注意&#xff1a; 1.执行 npm config set registry https://registry.npm.taobao.org 2.执行 npm install 3.执行 $env:NODE_OPTIONS“–openssl-legacy-provider” b.输入…...

AI基础知识(2)--决策树,神经网络

1.什么是决策树&#xff1f; 决策树是一类常见的机器学习方法&#xff0c;决策树是基于树的结构来进行决策。决策过程中提出的每一个问题都是对于属性的“测试”&#xff0c;决策的最终结论对应了我们希望的判定结果。一个决策树包含一个根节点&#xff0c;若干个内部节点和若…...

蓝桥杯C++大学B组一个月冲刺记录2024/3/21

蓝桥杯C大学B组一个月冲刺记录2024/3/20 规则&#xff1a;每日三题 今日的题很简单┗|&#xff40;O′|┛ 嗷~~ 1.奶酪 现有一块大奶酪&#xff0c;它的高度为 h &#xff0c;它的长度和宽度我们可以认为是无限大的&#xff0c;奶酪中间有许多半径相同的球形空洞。 我们可以在…...

由浅到深认识C语言(14):枚举

该文章Github地址&#xff1a;https://github.com/AntonyCheng/c-notes 在此介绍一下作者开源的SpringBoot项目初始化模板&#xff08;Github仓库地址&#xff1a;https://github.com/AntonyCheng/spring-boot-init-template & CSDN文章地址&#xff1a;https://blog.csdn…...

矽力杰 Silergy SY8024 双路同步降压转换器 规格书 佰祥电子

突破双路降压集成度低、小体积大电流、高频低纹波痛点&#xff01;SY8024&#xff1a;双路 3A 输出 1.5MHz 高频的五大核心优势便携智能设备双路降压供电场景普遍存在双路供电需双芯片导致体积偏大、高频小体积方案转换效率偏低、双路独立控制与防护能力不足三大行业痛点。作为…...

从理论到实践:利用Smith预估器解决网络控制系统中的双延迟问题(含Matlab/Simulink案例)

1. 网络控制系统中的双延迟问题 想象一下你在玩远程操控的赛车游戏&#xff0c;按下手柄按键后赛车总要延迟半秒才响应——这就是典型的控制延迟。而在工业自动化领域&#xff0c;这种延迟可能造成更严重的后果&#xff1a;机械臂失控撞毁设备、化工反应釜温度失控引发事故。网…...

终极指南:Gumbo Parser重构如何实现30-40%性能飞跃?完整技术分析

终极指南&#xff1a;Gumbo Parser重构如何实现30-40%性能飞跃&#xff1f;完整技术分析 【免费下载链接】gumbo-parser An HTML5 parsing library in pure C99 项目地址: https://gitcode.com/gh_mirrors/gum/gumbo-parser Gumbo Parser作为一款纯C99编写的HTML5解析库…...

3步高效去除视频水印:LAMA模型智能批量处理终极指南

3步高效去除视频水印&#xff1a;LAMA模型智能批量处理终极指南 【免费下载链接】WatermarkRemover 批量去除视频中位置固定的水印 项目地址: https://gitcode.com/gh_mirrors/wa/WatermarkRemover 还在为视频中那些顽固的水印标识而烦恼吗&#xff1f;想要获得纯净的视…...

# 发散创新:基于Rust的内存安全防御机制实战解析在现代软件开发中,**内存安全漏洞**(如缓冲区溢出

发散创新&#xff1a;基于Rust的内存安全防御机制实战解析 在现代软件开发中&#xff0c;内存安全漏洞&#xff08;如缓冲区溢出、空指针解引用、Use-After-Free等&#xff09;仍是导致系统崩溃甚至远程代码执行的核心风险点。传统语言如C/C因缺乏运行时保护机制而屡遭攻击&…...

Python如何计算移动平均值_Pandas实现滚动窗口函数应用

rolling()默认右对齐&#xff0c;前N?1行不足时返回NaN&#xff1b;需中心对齐用centerTrue&#xff1b;时间序列优先用rolling(5D)&#xff1b;min_periods1可首行出值但掩盖稀疏问题&#xff1b;apply()须返回标量&#xff0c;推荐lambda x: x.quantile(0.5)&#xff1b;ski…...

Flutter状态管理详解与最佳实践

Flutter状态管理详解与最佳实践 什么是Flutter状态管理&#xff1f; 在Flutter应用中&#xff0c;状态管理是指管理应用中数据的存储、更新和传递的过程。状态管理对于构建复杂的Flutter应用至关重要&#xff0c;它可以帮助我们更好地组织代码&#xff0c;提高应用的可维护性和…...

Phi-3 Forest Laboratory跨学科知识融合效果:解释STM32开发与Matlab仿真概念

Phi-3 Forest Laboratory跨学科知识融合效果&#xff1a;解释STM32开发与Matlab仿真概念 最近在试用Phi-3 Forest Laboratory这个模型&#xff0c;它有个特点让我印象挺深的&#xff0c;就是能把不同领域的知识串起来讲&#xff0c;讲得还挺明白。这有点像你身边那个“什么都懂…...

郭老师-向内求,是强者的起点

向内求&#xff0c;是强者的起点 ——弱者归咎于外&#xff0c;强者反求诸己“找别人原因&#xff0c;是普通人的本能&#xff1b; 找自己原因&#xff0c;是强者的修行。”&#x1f33f; 弱者向外求因&#xff0c; 强者向内得果。 这一念之差&#xff0c; 决定了人生的天壤之别…...

2026最权威的十大AI辅助论文平台实测分析

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek DeepSeek系列论文系统地阐述大型语言模型技术架构、训练范式&#xff0c;核心创新涉及混合专…...