背景:服务器是windows server 2008 R2系统,点击一个导出报表功能按钮,页面报如下错:
tomcat控制台里也报类似的错误,下面说一下定位和调优方法————
定位:
1、打开cmd控制台,因为是windows系统,使用ps -ef|grep java报不是内部命令,然后我还特意百度了一下T T
tasklist可以查看全部进程的进程id,如果不确定是哪个,可以在window任务管理器,跳转到进程查看tomcat运行的是哪个进程,其实就是java.exe啦~~
或者使用命令:netstat -aon |findstr "8080",根据端口号查看pid,这两种方法都是可以的~
2、然后根据pid查看是哪个类或方法占用内存最多,使用的命令是:jmap -histo 1100 >1.txt,1100是我tomcat的pid
3、cmd里直接1.txt打开日志,查看占用内存最高的是哪个类~推荐使用notepad++等专门的文本查看工具,用记事本打开