我们有一个在 Tomcat 7 中运行的 struts2 Web 应用程序,它间歇性地遇到同样的问题:
- 应用程序完美正常运行
- 在一段时间后(从 10 分钟到 7 天不等),应用程序减速到停止
- catalina.out 中的多个 java.lang.OutOfMemory 错误
- Linux free -m 显示所有物理和交换内存已用完(即使我在 setenv.sh 中设置了 Xmx8G)
我已将 Tomcat 配置为在 OutOfMemory 上创建自动堆转储,当我在 Eclipse 中使用 jmap 或 MAT 分析转储时,每个转储都显示相同的内容。所有内存都被 PageOutputStream 生成的近 100 万个 java.util.LinkedList$Node 占用。
由于这些节点似乎是由 PageOutputStream 生成的,它是 Struts 中页面渲染的一部分,我的想法是在我们的一个 JSP 页面中有一个无限循环的 Struts 标签,它正在创建所有这些链表节点,但我很难理解如何我可能会找出那个页面可能是什么。
我想知道是否有人知道将这个问题进一步隔离到一行代码或一个jsp页面的方法?