feign之间相互通信RequestInterceptor拦截器失效

本文描述了在SpringBoot项目中,两个服务A和B通过Feign进行通信时,如何解决因FeignClients配置导致的RequestInterceptor拦截器触发不稳定的问题,关键在于精确扫描Feign客户端类。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、问题描述

        前段时间碰到一个问题,有两个服务A和服务B,通过feign进行通信。因为feign之间无法直接传递请求头,只能传请求体。因此需要借助RequestInterceptor拦截器获取到请求头。服务B中设置了RequestInterceptor拦截器,但是在A进行feign调用B的时候有时候能触发B的RequestInterceptor拦截器,有时候又没有触发B的RequestInterceptor拦截器。

2、产生原因

        之所以有时能走到RequestInterceptor这里,有时走不到。这是由于我在启动类上的EnableFeignClients注解扫描的是包 @EnableFeignClients({"com.my.feign"})。 只要换成扫描具体的class就不会有这个问题了@EnableFeignClients(clients = {ProducerApiFeign.class})。       

        分析产生的原因我在FeignClientsRegistrar类里面打了断点,启动的时候看了执行步骤:

        1、启动类使用@EnableFeignClients({"com.my.feign"})

        2、启动类使用@EnableFeignClients(clients = {ProducerApiFeign.class})

3、解决方法

        把@EnableFeignClients({"com.my.feign"})

换成

        @EnableFeignClients(clients = {ProducerApiFeign.class})就行了。

4、参考代码

        为了复现这个问题,我简单写了一个生产者和消费者。

        

        代码:【免费】feign之间相互通信RequestInterceptor拦截器失效相关代码资源-优快云文库

项目结构说明:

MyEureka:

        使用@EnableEurekaServer使其作为eureka服务端。

     

MyProducer:

        生产者服务

MyCustomer:

        消费者服务

        

5、总结

       无

6、参考资料

@FeignClient配置 configuration 不生效_feignclient configuration不生效-优快云博客

spring boot + feign + eureka报错Load balancer does not have available server for client的可能解决办法_springcloud eureka balancer冲突-优快云博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

金斗潼关

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

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

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

打赏作者

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

抵扣说明:

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

余额充值