InetAddress.getLocalHost() 执行非常慢

昨天同事反馈网关的请求非常慢,一个获取的token的接口响应都超过了30s,还好只是测试环境。

经过验证,几乎所有接口响应都很慢,很多都响应超时。

排查步骤:

0. 本地启动项目测试,没有这个问题。而且生产环境也没这个问题,推测是 环境问题,或择资源问题导致。

1. 通过arthas的trace命令来查找方法执行链路上的 哪里比较耗时。

但通过验证,调用方等待请求响应,花了70s,从arthas的日志来看,只花费了0.01ms。

因此推测,耗时是在进入目标方法只之前,都已经卡主了。

2. 由于拦截器比较多,就没有去分析哪个拦截去出了问题。其实也可以通过arthas 进行定位。

3. 通过jprofiler定位到了 阻塞的线程,然后看得了方法的调用堆栈信息。定位到了应该是InetAddress.getLocalHost()阻塞了,然后在通过 arthas的trace命令跟踪这个方法,确认了问题。

InetAddress.getLocalHost() 执行非常慢_第1张图片

jprofiler截图

InetAddress.getLocalHost() 执行非常慢_第2张图片

arthas截图

参考文档:

arthas帮助文档:trace | arthas

知乎网友的同样问题:InetAddress.getLocalHost() 执行很慢? - 知乎

你可能感兴趣的:(后端,Java,问题,java,开发语言,linux)