再战 “并发调用Feign时出现的问题”

        首先发表一下操蛋的心情,之前feign调用的并发调用问题,通过参考网上文档和之前的项目做了一些配置,当时测试没有问题,可以这两天又出现了这个问题。之前在处理这个问题的时候就对Feign不懂,多种多样的配置,hystrix配置、隔离模式等等都是懵逼的,本来想着解决了就算了,万万没想到又遇到了。于是决定再战"并发调用Feign时出现的问题",本次目标是彻底搞定它。

        本次决定用Debug源码的方式学习,在Debug之前首先需要定位目标。定义过一个问题清单围绕这些问题进行一步一步的Debug。一定要彻底搞懂呀,脑瓜子疼~~。有点偏向日记了,正经人谁写日记,谁把心里话写道日记里~~,你会么。我不会。

问题清单

        feign是做什么的?

        hystrix是做什么的?

        什么执行流程?

        有哪些配置?

        针对这个问题需要怎么配置?

~~~ 留空 ~~~ 指向另一篇记录技术型文档的链接来回答 前面两个问题和总结执行流程。

Debug开始

        环境的配置就不说了直接从Debug的起点开始。随便整个Feign 然后断点打在rangeAll()函数,一路执行。

@FeignClient(name = "nsrep-new-res")
public interface NewResFeign {
    @GetMapping("/ranges/all")
    String rangeAll();
}


@SpringBootTest
public class TestC {

    @Resource
    private NewResFeign newResFeign;


    @Test
    public void t1(){
        String s = newResFeign.rangeAll();
        System.out.println(s);
    }
}

已经结束~。又放弃了一次学习源码的机会。

        首先这个问题一开始考虑的思路就有问题。信号量获取不到。可以不用hystrix 不用熔断呀。

       

配置 ·网飞/海斯特里克斯 维基 ·吉特哈布 (github.com)

没想到呀,没想到,你小子浓眉大眼的竟然干出这种事~~。

本以为看官方配置,把自己服务的feign的信号量调大之后就可以了。结果还是不行~~。

突然想到了一个问题,为什么会触发CallBack的操作,先定义一下角色 我的服务是B,其他人的服务是A , 是A服务通过Feign调用B服务,出现了“没有获取到信号量”,之前认为这个信号量是B服务控制的然后A服务进行获取。今天才感觉应该是 A服务Feign的信号量不足,导致出现这个问题。之前一直没有想过这个问题。

        其实就是思路错了,加上确实不了解。主要没有理解到 消费方 和 提供方的关系。简单画个图理一下思路。

         用户请求A服务,然后通过FeignClient 请求B服务。 FeignClient 去请求B服务之前会先去“信号量池”获取信号量,获取到了才会去调用。否则就走CallBack路线给用户报错。

        图化的有问题,大概理解就可以。以上是Feign + Hystrix 的情况,并且隔离策略选用的是 信号量的方式。

        主要报错有误导性,报错是 Feign Client B  Callback  也就是请求B服务出现了问题,所以前面一直意味是 B服务的问题

        以上思路还待测试。如果有问题我会在回来的 

### 回答1: 使用@async注解可以在方法调用将其作为异步任务执行。而在@async注解内调用feign,则可以实现异步的远程调用服务。 在使用@async注解,需要在方法前加上该注解,并返回Future或CompletableFuture对象。然后在方法体内,可以使用feign调用远程服务,实现异步的远程服务调用。 使用@async注解内调用feign可以提高程序并发性能,减少线程阻塞等待远程服务响应的间。同,由于使用了异步调用,系统可以更加容易地扩展到多个服务实例,更好地支持高并发和负载均衡。 需要注意的是,使用@async注解内调用feign需要确保异步任务不会阻塞主线程。因此,在调用方法需要使用合适的线程池,以避免线程池耗尽的情况发生。此外,需要仔细评估异步调用对于整个系统的影响,以确保异步调用不会影响系统稳定性和可靠性。 总之,使用@async注解内调用feign可以提高程序的性能和可扩展性,但需要仔细权衡异步调用的影响,并确保代码的正确性和稳定性。 ### 回答2: @async注解是Spring Boot中的一个注解,它指示Spring Boot应该在另一个线程中异步执行方法调用Feign是一个轻量级的HTTP客户端库,用于将RESTful服务作为接口进行访问。在Spring Boot应用程序中使用Feign,可以使用@FeignClient注解将Feign客户端绑定到REST服务。在异步调用Feign库之前,必须在Spring Boot应用程序中配置异步分组。在此之后,就可以在@async注解中调用Feign库了。 具体实现步骤如下: 首先,需要为Spring Boot应用程序配置异步编组。这可以通过在定义的配置类上添加@EnableAsync和@Configuration注解来完成。这样,Spring Boot应用程序就能够在不同的线程中执行方法调用。 然后,在定义的Feign客户端接口上添加@FeignClient注解,并指定REST服务的名称。接着在该接口上定义异步方法,这些方法必须添加@async注解,以通知Spring Boot应该异步执行这些方法。最后,调用异步方法,必须通过Feign库向REST服务发出请求,以获取所需的数据。 使用@async注解调用Feign库非常简单,只需要在Spring Boot应用程序中进行正确的配置,并使用Feign客户端接口定义异步方法即可。这样,应用程序就能在不同的线程中异步执行Feign调用,从而提高应用程序的响应性和性能。 ### 回答3: @async注解是用于异步调用方法的注解,在调用方法会开启一个新的线程来执行方法体中的代码,从而不会阻塞主线程。而Feign是一个声明式的Web Service客户端,可以让我们更容易地调用其它微服务。 在使用@async注解内调用Feign,需要注意以下几点: 1. 定义Feign客户端并注入到调用方法所在的类中。 2. 在调用方法中使用@autowired注解将Feign客户端注入进来。 3. 在调用方法中使用@async注解,表示异步调用。 例如,下面是一个使用@async注解内调用Feign的示例代码: ``` @Service public class DemoService { @Autowired private OtherServiceClient otherServiceClient; @Async public void callOtherService() { otherServiceClient.doSomething(); } } @FeignClient(name = "other-service", url = "http://localhost:8001") public interface OtherServiceClient { @RequestMapping(value = "/do-something", method = RequestMethod.GET) void doSomething(); } ``` 在上面的代码中,DemoService中有一个名为callOtherService的方法,使用了@async注解,表示该方法是一个异步方法。另外,DemoService中还使用了@Autowired注解将OtherServiceClient注入进来。 OtherServiceClient则是一个Feign客户端,使用@FeignClient注解将其定义为一个Feign客户端,其中name表示服务名,url表示服务的URL地址。 在callOtherService方法中,调用了OtherServiceClient的doSomething方法,表示要调用other-service服务的/do-something接口。由于callOtherService使用了@async注解,因此doSomething方法的调用将会在一个新的线程中执行,不会阻塞主线程。 总的来说,使用@async注解内调用Feign可以提高代码的并发能力,避免因为调用其他服务而阻塞主线程。同由于Feign是一个声明式的客户端,使得我们调用其他服务也变得更加简单。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值