JVM死锁导致线程不可用,然后会瞬间起N个线程,当然也是不可用的,因为需要的对象死锁,然后耗尽文件句柄导致外部TCP无法建议拒绝服务,jstack之后就会恢复。
解决办法:替换中间件类库 ,比如httpclient的。
原因大致是:
某个switch分支缺少memory barrier的正确处理,导致外部应用如JVM的lock被错误锁住;一般jstack连后就恢复。
https://github.com/torvalds/linux/commit/76835b0ebf8a7fe85beb03c75121419a7dec52f0
https://www.zhihu.com/search?type=content&q=jvm%E5%81%87%E6%AD%BB
https://ma.ttias.be/linux-futex_wait-bug/
JVM内存模型-重排序&内存屏障
内核源码:https://mirrors.edge.kernel.org/pub/linux/kernel/