feign 熔断 没有 启用原因

具体 如何 配置I feign 参考 https://www.cnblogs.com/songlu/p/9934447.html

网上 都说是

feign.hystrix.enabled=true

开启熔断 结果还是不行,主要原因是因为,这是老版本写法,

新版本代码是

feign.circuitbreaker.enabled=true

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot Feign是一个基于RestTemplate的声明式Web Service客户端,它简化了微服务之间的远程调用。Feign通过注解方式定义接口,内部封装了负载均衡和服务熔断的功能,提供了一种更简洁、更方便的方式进行服务之间的通信。 熔断机制是一种保护机制,用于防止由于服务不可用或无法正常响应而导致的服务雪崩效应。假设某个微服务在高峰期间不可用,当其他微服务不断向该服务发送请求时,由于无法得到正常的响应,会占用大量的线程和资源,最终导致整个系统崩溃。为了解决这个问题,可以使用熔断器。 熔断器是Feign中的一种机制,用于处理服务调用失败或超时的情况。当服务调用超时或出现错误时,熔断器会暂时中断对该服务的调用,并返回给客户端一个预先定义的默认值或错误信息,而不是一直等待响应。这样可以保护系统不受故障服务的影响,提高系统的可用性和稳定性。 在Spring Boot中使用Feign进行服务调用熔断的具体步骤如下: 1. 在使用Feign的微服务项目中引入相应的依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 2. 创建Feign接口,并使用@FeignClient注解指定要调用的微服务的名称: ```java @FeignClient(value = "service-name", fallback = ServiceFallback.class) public interface ServiceClient { @GetMapping("/api/path") String invokeService(); } ``` 3. 实现熔断的回退逻辑,创建一个Fallback类,实现Feign接口并定义相应的错误处理方法: ```java @Component public class ServiceFallback implements ServiceClient { @Override public String invokeService() { return "Fallback message"; } } ``` 4. 在应用主类上添加@EnableFeignClients注解启用Feign熔断功能: ```java @SpringBootApplication @EnableFeignClients public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 通过以上步骤,当微服务调用超时或出现错误时,Feign会自动调用相应的熔断器回退逻辑并返回默认值,确保系统的稳定性。可以根据实际情况自定义熔断处理逻辑,比如记录日志、发送警报等操作,以便及时处理故障。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值