背景介绍
最近,将应用手动部署到新的CentOS环境上,JRE/Tomcat都是新安装的,所以还没对JVM进行优化。习惯了本地开发和持续集成系统上现成的环境,往往会忽略JVM参数的配置。所以在启动没多久后就OOM了。。。
JVM优化
优化前
应用启动后GC状态如下图所示,从老年代可以看到应用已经执行了9次Full GC,而且消耗了14.418s,可以说这种状态应用是持续不了多久的。
图1 优化前初始运行
JVM为了获取足够的可用空间还会执行Full GC,此时垃圾收集器不是并行执行Full GC,所以Stop The World(STW)到来了。再看看第二张图的变化,老年代达到1.273G,已经完全占满,没有额外的空间可供分配的,就会出现OOM。如果是一个Web应用,我们就会发现前端各种无响应、各种超时。
图2 优化前运行一段时间后
执行优化
JVM添加哪些参数会优化应用呢?不妨再从第二张图看看,我们的应用缺什么。