Feign 服务间调用失败-熔断

到了需要服务间调用的需求,踩了个坑,在此记录一下。

需求是这样的 A 服务需要调用 B 服务的接口

这是 A 服务调用 B 服务写的接口

A 服务 配置spring ApplicationName

spring: 
  application:
    name: a-service

B 服务 配置spring ApplicationName

spring: 
  application:
    name: b-service
@FeignClient(name = "b-service", fallback = B.class)
public interface Aservice{
    @PostMapping("/selectA/{typeId}")
    String selectPlanCount(@PathVariable("typeId")Integer typeId);
}

熔断

@Slf4j
@Component
public class AserviceImpl implements Aservice{
    @Override
    public String selectPlanCount(Integer typeId) {
        String errorMsg = "触发接口熔断,默认返回";
        log.info(errorMsg);
        return errorMsg ;
    }
}

发现只要一调用就熔断 ,结果发现是 rest 地址没写全

@Slf4j
@CrossOrigin
@RestController
@RequestMapping("anls")
@Api(tags = {"分析服务"})
public class AnalysisController {
    @PostMapping("/selectA/{typeId}")
    public ResultDTO<PageInfo<BizEcOrderVo>> getAllOrderByPage(@PathVariable("typeId") Integer typeId) {
        return "ok";
    }
}

修改后 正常访问

@FeignClient(name = "b-service", fallback = B.class)
public interface Aservice{
    @PostMapping("anls/selectA/{typeId}")
    String selectPlanCount(@PathVariable("typeId")Integer typeId);
}

本次feign 服务间调用踩坑到此结束。

如有哪里写的不好请指出,共同进步。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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会自动调用相应的熔断器回退逻辑并返回默认值,确保系统的稳定性。可以根据实际情况自定义熔断处理逻辑,比如记录日志、发送警报等操作,以便及时处理故障。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值