现象:线上服务无法对接口进行响应,接口全部超时,但是Java进程还是在运行中,jvm GC日志正常。
jstack命令查看线程情况:
大量线程处于BLOCKED状态,等待锁0x00000000cbc9b9c8的释放;
该锁被持有的线程:scheduling-1,是一个异步线程。
通过观察上图,发现锁在getAccessToken方法中被获取,该方法是一个同步方法,由于socket连接长时间阻塞,导致锁无法释放。
代码修改方案:设置http connectionTimeout 和 readTimeout
标签:web,释放,服务,记录,响应,线程,方法 From: https://www.cnblogs.com/hekk/p/18662572