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/

本文探讨了JVM中出现的死锁问题及其对系统的影响,例如引发大量无效线程和资源耗尽等现象。文章提供了具体的解决方案,包括更换中间件类库,并深入分析了可能的原因,涉及内存屏障的正确使用。
6406

被折叠的 条评论
为什么被折叠?



