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

Spring Cloud Alibaba-Feign整合Sentinel

第1步: 引入sentinel的依赖

<!--sentinel客户端-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

第2步: 在配置文件中开启Feign对Sentinel的支持

feign:
sentinel:enabled: true

第3步: 创建容错类

//容错类要求必须实现被容错的接口,并为每个方法实现容错方案
@Component
@Slf4j
public class ProductServiceFallBack implements ProductService {@Overridepublic Product findByPid(Integer pid) {Product product = new Product();product.setPid(-1);return product;}
}

第4步: 为被容器的接口指定容错类

//value用于指定调用nacos下哪个微服务
//fallback用于指定容错类
@FeignClient(value = "service-product", fallback = ProductServiceFallBack.class)
public interface ProductService {@RequestMapping("/product/{pid}")//指定请求的URI部分Product findByPid(@PathVariable Integer pid);
}

第5步: 修改controller

@RestController
@Slf4j
public class OrderController {@Autowiredprivate OrderService orderService;@Autowiredprivate ProductService productService;//下单--fegin@RequestMapping("/order/prod/{pid}")public Order order(@PathVariable("pid") Integer pid) {log.info("接收到{}号商品的下单请求,接下来调用商品微服务查询此商品信息", pid);//调用商品微服务,查询商品信息Product product = productService.findByPid(pid);if (product.getPid() == -1) {Order order = new Order();order.setPname("下单失败");return order;}log.info("查询到{}号商品的信息,内容是:{}", pid, JSON.toJSONString(product));//下单(创建订单)Order order = new Order();order.setUid(1);order.setUsername("测试用户");order.setPid(pid);order.setPname(product.getPname());order.setPprice(product.getPprice());order.setNumber(1);orderService.createOrder(order);log.info("创建订单成功,订单信息为{}", JSON.toJSONString(order));try {Thread.sleep(100);} catch (InterruptedException e) {e.printStackTrace();}return order;}
}

第6步: 停止所有 shop-product 服务,重启 shop-order 服务,访问请求,观察容错效果

扩展: 如果想在容错类中拿到具体的错误,可以使用下面的方式

@FeignClient(value = "service-product",//fallback = ProductServiceFallBack.class,fallbackFactory = ProductServiceFallBackFactory.class)
public interface ProductService {//@FeignClient的value + @RequestMapping的value值 其实就是完成的请求地址
"http://service-product/product/" + pid@RequestMapping("/product/{pid}")//指定请求的URI部分Product findByPid(@PathVariable Integer pid);
}
@Component
public class ProductServiceFallBackFactory implements
FallbackFactory<ProductService> {@Overridepublic ProductService create(Throwable throwable) {return new ProductService() {@Overridepublic Product findByPid(Integer pid) {throwable.printStackTrace();Product product = new Product();product.setPid(-1);return product;}};}
}

http://www.lryc.cn/news/154495.html

相关文章:

  • zabbix配置钉钉告警、和故障自愈
  • Web安全测试(五):XSS攻击—存储式XSS漏洞
  • 本地PC机通过SSH方式远程Jetson
  • 面向对象 学习黑马视频(03)
  • FinClip 支持创建 H5应用类小程序;PC 终端 优化升级
  • YOLOV8实例分割——详细记录环境配置、自定义数据处理到模型训练与部署
  • 2309ddocx02文档
  • 第一章初识微服务
  • 微信小程序电影票订票小程序软件设计与实现
  • Redis 缓存预热+缓存雪崩+缓存击穿+缓存穿透
  • java 面试题汇总整理
  • 淘宝开放平台免审核接入 获取淘宝卖家订单列表订单详情API
  • Mybatis中的关系映射
  • 领域建模之数据模型设计方法论
  • springboot毕业生信息招聘平台设计与实现
  • 开发前期准备工作
  • k8s deployment服务回滚,设置节点为不可调度
  • 信息系统安全运维和管理指南
  • 现货黄金代理好吗?
  • BCSP-玄子Share-Java框基础_双系统Redis安装与基础语法
  • android system_server WatchDog简介
  • 华为---OSPF协议优先级、开销(cost)、定时器简介及示例配置
  • MEMORY-VQ: Compression for Tractable Internet-Scale Memory
  • Netty—ChannelHandler
  • Android 集成onenet物联网平台
  • java八股文面试[JVM]——如何打破双亲委派模型
  • 一加11/Ace2/10Pro手机如何实现全局120HZ高刷-游戏超级流畅效果
  • 微服务主流框架概览
  • Python Flask Web开发二:数据库创建和使用
  • 快速学会git版本管理——上传gitee仓库