V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
BlackZhu
V2EX  ›  程序员

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

  •  
  •   BlackZhu · 2022-03-08 21:14:50 +08:00 · 1263 次点击
    这是一个创建于 969 天前的主题,其中的信息可能已经有所发展或是发生改变。

    背景:项目使用 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 默认的最大等待时间

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

    3 条回复    2022-03-09 21:37:58 +08:00
    Kyle18Tang
        1
    Kyle18Tang  
       2022-03-09 09:35:28 +08:00
    换个 RequestFactory, 使用 OkHttp3ClientHttpRequestFactory 试试?
    agzou
        2
    agzou  
       2022-03-09 10:11:15 +08:00
    看了下代码,synchronized 加在方法上的,锁的是对象,nacos 和 restTemplate 用的肯定不是同一个 HttpURLConnection 对象吧。。是不是找错问题了
    BlackZhu
        3
    BlackZhu  
    OP
       2022-03-09 21:37:58 +08:00
    @Kyle18Tang 谢谢 我试一下
    @agzou 你说的确实有道理 是我对 synchronized 理解错了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2472 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 10:31 · PVG 18:31 · LAX 03:31 · JFK 06:31
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.