在模块中使用了SpringBoot的@Async注解实现线程异步调用,然后在使用test测试类对功能进行测试时,发现代码执行未完成,也不报错,使用断点方式锁定问题,报错细节如下:
Error creating bean with name 'retryableRibbonLoadBalancingHttpClient' defined in org.springframework.cloud.netflix.ribbon.apache.HttpClientRibbonConfiguration: Unsatisfied dependency expressed through method 'retryableRibbonLoadBalancingHttpClient' parameter 2
偶尔还会有如下报错:
Failed to instantiate [com.netflix.loadbalancer.ILoadBalancer]: Factory method 'ribbonLoadBalancer' threw exception; nested exception is java.lang.NoClassDefFoundError: Could not initialize class com.netflix.loadbalancer.PollingServerListUpdater$LazyHolder
就挺搞不懂的,怎么还能跟负载均衡扯上关系,经过长久的折磨,认为问题出在测试中,然后注掉注解后,测试成功。
原因可能就是在测试方法异步调用其他方式之后,开启了分线程去执行任务,由于只是测试,调用完成后,测试类也就是主线程就结束执行,关掉了线程,分线程此时还在继续执行,就会报异常,但是由于主线程已经结束,所以也看不到报错,很折磨!
也算是get到了一个新知识点。