登录
首页 >  文章 >  java教程

JAVA服务假死,请求无响应却非OOM?如何排查Poller线程死循环问题

时间:2024-12-10 16:52:03 122浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《JAVA服务假死,请求无响应却非OOM?如何排查Poller线程死循环问题》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

JAVA服务假死,请求无响应却非OOM?如何排查Poller线程死循环问题

JAVA服务假死,请求无法响应,疑似OOM

某位用户遇到了一个问题,其某个服务下的所有 URL 请求都无法响应,持续转圈圈。经过初步排查,系统内存、GC 信息和线程堆栈信息都正常。尽管日志信息没有异常,但问题仍然存在。

一位经验丰富的技术人员分析了该问题。他认为,如果服务器确实 OOM 了,那么在无法获取更多内存空间的情况下,所有线程都会被阻塞。然而,在这种情况下,系统仍然能够接受socket 请求,但由于没有人处理读写,导致浏览器一直处于等待状态。

该技术人员提供了一个调试截图,展示了Poller线程的死循环。他指出,退出该循环的条件之一是 tomcat 关闭。当他通过调试修改变量让Poller线程结束时,他观察到了与用户描述相同的现象:socket 请求被接收,但未被处理,导致浏览器无限等待。

此外,技术人员检查了 Poller 源码并发现另一个退出条件。如果 Poller 在处理请求时遇到异常,它也会退出循环。他建议用户检查 OOM 的原因,因为这可能是导致异常并最终退出 Poller 线程的原因。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《JAVA服务假死,请求无响应却非OOM?如何排查Poller线程死循环问题》文章吧,也可关注golang学习网公众号了解相关技术文章。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>