JVM性能调优监控工具使用详解
发布时间:2019-11-02 22:45:29  所属栏目:空间  来源:zhisheng的blog 
            导读:现实企业级Java应用开发、维护中,有时候我们会碰到下面这些问题: OutOfMemoryError,内存不足 内存泄露 线程死锁 锁争用(Lock Contention) Java进程消耗CPU过高 ...... 这些问题在日常开发、维护中可能被很多人忽视(比如有的人遇到上面的问题只是重启服
                
                
                
            | class name是对象类型,说明如下: 
 还有一个很常用的情况是:用jmap把进程内存使用情况dump到文件中,再用jhat分析查看。jmap进行dump命令格式如下: 
 我一样地对上面进程ID为21711进行Dump: 
 dump出来的文件可以用MAT、VisualVM等工具查看,这里用jhat查看: 
 注意如果Dump文件太大,可能需要加上-J-Xmx512m这种参数指定最大堆内存,即jhat -J-Xmx512m -port 9998 /tmp/dump.dat。然后就可以在浏览器中输入主机地址:9998查看了:  上面红线框出来的部分大家可以自己去摸索下,最后一项支持OQL(对象查询语言)。 D、jstat(JVM统计监测工具) 语法格式如下: 
 vmid是Java虚拟机ID,在Linux/Unix系统上一般就是进程ID。interval是采样时间间隔。count是采样数目。比如下面输出的是GC信息,采样时间间隔为250ms,采样数为4: 
 要明白上面各列的意义,先看JVM堆内存布局:  (编辑:鹰潭站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! | 
