作者:未完成交响曲,资深Java工程师!目前在某一线互联网公司任职,架构师社区合伙人!
我们在使用Hystrix时,大部分情况下都是直接基于SpringCloud的相关注解来完成请求调用的。我们有个项目中是手动创建HystrixCommand来包裹RestTemplate发起请求的。但是在服务运行过程中,发现一个情况,就是当HystrixCommand超时返回fallback结果后,RestTemplate请求过程还没有结束,导致线程池占用较多。
这里通过一个简单的测试,对RestTemplate和HystrixCommand设置不同的超时时间,来观察在HystrixCommand执行过程中的细节。
测试观察
模拟外部服务:
创建一个springboot服务,提供一个接口:等待5秒后返回数据
@RestController
public class DataController {
@RequestMapping("queryData")
public String queryData() {
// 等待5s后,返回随机字符串
long sleepTime = 5000;
try {
Thread.sleep(sleepTime);
} catch (InterruptedException e) {
e.printStackTrace();
}
return UUID.randomUUID().toString();
}
}
测试代码:
public class HystrixCommandTest {
private static final SimpleDateFormat df = new SimpleDateFormat("HH:mm:ss");
// http请求超时时间
private static final int HTTP_TIMEOUT =