feign整合sentinel做降级知识点

1,配置依赖

<!-- Feign远程调用依赖  -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
<!--sentinel-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>

2,编写feign接口

3,编写降级类

4,需要通过SpringBoot的自动加载机制来加载这些fallback类(降级类)

首先编写一个配置类:

指定加载配置类:

这样所有在其中定义的fallback类都会被加载了。

5,开启feign对sentinel降级支持

feign:
  client:
    config:
      default: # default全局的配置
        loggerLevel: BASIC # 日志级别,BASIC就是基本的请求和响应信息
  httpclient:
    enabled: true # 开启feign对HttpClient的支持
    max-connections: 200 # 最大的连接数
    max-connections-per-route: 50 # 每个路径的最大连接数
  sentinel:
    enabled: true # 开启降级

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在微服务架构中,Feign是一个声明式的HTTP客户端,它使得编写HTTP请求变得更加简单。它使用了Ribbon来实现负载均衡,并且集成了Hystrix来提供服务降级和容错功能。 而Sentinel是一个开源的流量控制组件,它能够对系统中的API进行实时监控、统计和保护。Sentinel可以通过定义规则来限制对服务的访问,当达到设定的阈值时可以进行流量控制、熔断降级等操作,以保证系统的稳定性和可靠性。 当使用Feign进行服务调用时,我们可以配合使用Sentinel来实现服务的降级。具体步骤如下: 1. 引入FeignSentinel的依赖: 在项目的pom.xml文件中添加FeignSentinel的依赖,例如: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> </dependency> ``` 2. 配置FeignSentinel: 在项目的配置文件中配置FeignSentinel相关的属性,例如: ```yaml spring: cloud: sentinel: transport: dashboard: localhost:8080 port: 8719 feign: sentinel: enabled: true ``` 3. 定义Feign接口: 在接口上使用`@FeignClient`注解,指定要调用的服务名和降级处理的类,例如: ```java @FeignClient(value = "service-provider", fallback = HelloFallback.class) public interface HelloService { @GetMapping("/hello") String hello(); } ``` 4. 实现降级处理类: 创建一个实现了Feign接口的降级处理类,例如: ```java @Component public class HelloFallback implements HelloService { @Override public String hello() { return "Fallback message"; } } ``` 使用FeignSentinel进行服务降级后,当服务调用失败或达到设定的流量控制阈值时,将会执行降级处理类中定义的逻辑,返回预设的降级结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Winter.169

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值