【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel

我们开始吧

首先我们需要在配置文件中配置Fegin的相关规则

#开启fegin对sentinel支持
feign:
  sentinel:
    enabled: true

然后我们创建容错实现类
【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel_第1张图片

其次就是在Fegin调用接口的时候加上fallback
【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel_第2张图片
我们在controller中编写相关逻辑

if (product.getPid()==-1){
    Order order = new Order();
    order.setPid(-1);
    order.setPname("下单失败");
    return order;
}

然后我们测试一下。当商品微服务挂掉以后可以看到会自动进入容错逻辑。
【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel_第3张图片

这样我们就实现了相关的容错,但是这样也会有一个问题,我们这样是没有异常的,不方便我们的查找,其实还有另外一个方式,就是实现fallbackfactory
其实和fallback是差不多的。
我们来实现一下。新建ProductServiceFallbackFactory
【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel_第4张图片

然后在配置的时候使用(两个不能同时使用)
【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel_第5张图片
再次测试就可以看到我们的容错
【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel_第6张图片
【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel_第7张图片

这样我们就完成了基本的容错实现机制
后期会在这个项目上不断添加,喜欢的请点个start~\
项目源码参考一下分支220216_xgc_FeginAndSentinel\
Gitee:https://gitee.com/coderxgc/sp...\
GitHub:https://github.com/coderxgc/s...

你可能感兴趣的:(【SpringCloud-Alibaba系列教程】9.Fegin整合sentinel)