本文介绍: 本章,我们将通过实际案例讲解一个Web应用的内存溢出问题,该内存溢出问题的排查涉及Tomcat的一些底层原理,最终排查发现是由于请求超时问题导致,我们先来看下系统的背景。本章,我们通过一个实际案例分析了因为请求超时引起的内存溢出问题,以及相应的排查思路。解决这类问题的思路其实都是一致的,需要一步步去分析,在实践中积累经验,举一反三。
一、简介
本章,我们将通过实际案例讲解一个Web应用的内存溢出问题,该内存溢出问题的排查涉及Tomcat的一些底层原理,最终排查发现是由于请求超时问题导致,我们先来看下系统的背景。
1.1 系统背景
生产环境的一个系统发生告警,拿到生产日志后出现如下字样:Exception in thread "http-nio-8080-exec-1089" java.lang.OutOfMemoryError:Java heap space
。
很明显,Java堆内存区域发生了内存溢出异常。特别要注意的是http-nio-8080-exec-1089
,由于当时系统部署在tomcat中(8080端口),所以上面这段日志的意思就是tomacat工作线程在处理请求时发生了内存溢出异常。
为什么会是tomcat的工作线程发生异常? 这就涉及tomcat的一些基本原理。
1.2 tomcat基本原理
二、问题分析
2.1 内存快照
2.2 请求超时
三、系统优化
四、总结
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。