请教一个使用 RestTemplete 调用服务周期性卡顿的问题

2022-03-08 21:14:50 +08:00
 BlackZhu

背景:项目使用 spring nacos+RestTemplete

现象:服务之间调用偶发响应时间 10s(上下几十毫秒波动)

目前定位到的问题:接口之间通信是没问题的,在执行到下面两行代码时

response = request.execute();

handleResponse(url, method, response);

打断点后发现 response 已经有返回值,问题出在 handleResponse 方法里面,在获取 response 的 responseCode 时,会调用 HttpURLConnection.getResponseCode()方法,方法内会调用 getInputStream()检查连接是否可用,该方法由 synchronized 修饰

走到这一步发现 nacos 的 beat 方法也会一直调用到 HttpURLConnection.getResponseCode()方法,所以猜测可能是偶发性 nacos 占用了锁导致调用服务的线程一直阻塞,并且 10s 也符合 RestTemplete 默认的最大等待时间

目前不知道怎么进行下去解决问题了,希望大家能指点迷津!

1125 次点击
所在节点    程序员
3 条回复
Kyle18Tang
2022-03-09 09:35:28 +08:00
换个 RequestFactory, 使用 OkHttp3ClientHttpRequestFactory 试试?
agzou
2022-03-09 10:11:15 +08:00
看了下代码,synchronized 加在方法上的,锁的是对象,nacos 和 restTemplate 用的肯定不是同一个 HttpURLConnection 对象吧。。是不是找错问题了
BlackZhu
2022-03-09 21:37:58 +08:00
@Kyle18Tang 谢谢 我试一下
@agzou 你说的确实有道理 是我对 synchronized 理解错了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/838954

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX