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

sentinel使用手册

1.引入依赖

<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId></dependency>

2.yaml

spring:cloud:sentinel:transport:dashboard: localhost:8090 #sentinel控制台地址http-method-specify: true # 是否设置请求方式作为资源名称
feign:sentinel:enabled: true # 开启feign对sentinel的支持

3.降级

3.1 引入依赖

<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId></dependency>

3.2 创建降级方案

触发限流或熔断后的请求不一定要直接报错,也可以返回一些默认数据或者友好提示,用户体验会更好。
给FeignClient编写失败后的降级逻辑有两种方式:

  • 方式一:FallbackClass,无法对远程调用的异常做处理
  • 方式二:FallbackFactory,可以对远程调用的异常做处理,我们一般选择这种方式。

这里我们演示方式二的失败降级处理。
步骤一:在hm-api模块中给ItemClient定义降级处理类,实现FallbackFactory

@Component
public class ItemClientFallBackFactory implements FallbackFactory<ItemClient> {@Overridepublic ItemClient create(Throwable cause) {return new ItemClient() {@Overridepublic PageDTO<ItemDTO> queryItemByPage(PageQuery query) {//这里写降级逻辑return null;}@Overridepublic List<ItemDTO> queryItemByIds(List<Long> ids) {//这里写降级逻辑return List.of();}};}
}

步骤二: 在hm-api模块中的ItemClient接口中使用ItemClientFallbackFactory:

@FeignClient("item-service", fallbackFactory = ItemClientFallBackFactory.class)
public interface ItemClient {@GetMapping("/items/page")PageDTO<ItemDTO> queryItemByPage(PageQuery query);@GetMapping("/items")List<ItemDTO> queryItemByIds(@RequestParam("ids") List<Long> ids);

http://www.mrgr.cn/news/78687.html

相关文章:

  • 黑马JavaWeb开发跟学(十五).Maven高级
  • 基于Springboot + vue实现的小型养老院管理系统
  • 关于重构一点简单想法
  • 【Linux】硬链接和软连接(符号连接)
  • requests中data和json的区别
  • 【C++面向对象——类与对象】Computer类(头歌实践教学平台习题)【合集】
  • Android开发中的NSD扫描是什么
  • Node教程二
  • SQL进阶技巧:非等值连接--单向近距离匹配
  • 【ArkTS】使用AVRecorder录制音频 --内附录音机开发详细代码
  • aws(学习笔记第十五课) 如何从灾难中恢复(recover)
  • SpringBoot+Flowable快速实现工流_动态选择审批人员
  • 腾讯阅文集团Java后端开发面试题及参考答案
  • C++ STL 容器系列(三)list —— 编程世界的万能胶,数据结构中的百变精灵
  • MATLAB —— 机械臂工作空间,可达性分析
  • springboot学习-spring-boot-data-jdbc分页/排序/多表查询的例子
  • 点云处理中obb算法原理和法向量求解方法
  • PVE中VLAN的设置要点
  • 第十六届蓝桥杯模拟赛第二期题解—Java
  • 11 设计模式之代理模式(送资料案例)
  • 「Mac畅玩鸿蒙与硬件38」UI互动应用篇15 - 猜数字增强版
  • 2024前端面试经验分享
  • 【大模型实战篇】基于大模型GLM的Function Call实践
  • SQL进阶技巧:如何寻找同一批用户 | 断点分组应用【最新面试题】
  • 12 设计模式之工厂方法模式
  • 二叉搜索树讲解