linux机器内存溢出,占用内存最多的tomcat进程 被系统kill掉之后发现还有3个java进程?
linux机器启动tomcat之后,内存迅速飙高,free -m 查看只剩下一点点内存了,而使用top命令查看的时候,占用内存最高的java进程却只占用31.4%。 不久tomcat进程就被kill掉了,查看 cat /var/log/messages 发现竟然有3个java进程?
网上查资料,查看每个进程的占用内存,rss的值*4kb 大概都是2g多,总共就是6g多,而机器总内存8g,就内存溢出了。
现在问题是,为什么tomcat启动会有3个java进程呢?
1.tomcat应用下面有个服务中使用了线程池ThreadPoolTaskExecutor,CorePoolSize设置成了3, executor.setCorePoolSize(3) ,而我在声明ThreadPoolTaskExecutor的时候,没有使用static。跟这个会有关系吗?没有使用static导致ThreadPoolTaskExecutor对象创建在堆里,从而每个线程对应一个线程组里面一个进程?