JVM性能调优监控工具hprof使用详解
来源:互联网 发布:登录无限极网络 编辑:程序博客网 时间:2024/05/22 03:13
一、问题现状
现实企业级Java开发中,有时候我们会碰到下面这些问题:
- OutOfMemoryError,内存不足
- 内存泄露
- 线程死锁
- 锁争用(Lock Contention)
- Java进程消耗CPU过高
- ......
二、hprof文件的生成
如图所示,这里很清楚的表示,main()方法中有一个集合类型,,然后集合中的每一个元素都是com.charles.research.User的对象,并且每个对象的Shallow Heap和Retained Heap大小都为24byte。因为ArrayList一直存在,所以当对象足够多时候,就把heap弄满并且溢出了。这里创建了76340681个User对象,每个对象占据了24个byte,所以一共占据了24 * 7634068=183217632字节,差不多约为 174.72M 大小的堆空间。在这里 User对象的S hallow Size 和 Retained Size都为24byte呢?
我们要看下Shallow Size和Retained Size各是什么?
Shallow Size是对象本身占据的内存的大小,不包含其引用的对象。对于常规对象(非数组)的Shallow Size由其成员变量的数量和类型来定,而数组的ShallowSize由数组类型和数组长度来决定,它为数组元素大小的总和。
Retained Size=当前对象大小+当前对象可直接或间接引用到的对象的大小总和。(间接引用的含义:A->B->C,C就是间接引用) ,并且排除被GC Roots直接或者间接引用的对象
所以,我们这里的User类,因为我们机器是32位 WIN7系统,所以对象头占据8byte,它包含String对象引用(name),占据4byte,包含String对象引用(sex),占据4byte,包含一个int类型(age),占据4byte,所以一共占据8+4+4+4=20byte, 因为要补齐位数,所以最后尺寸为24byte. 这就是这个对象的本身大小(Shallow Heap)的大小。
小知识:为了说明补齐,大家也可以做实验,如果我们User中加一个String成员,那么User类大小仍然为24byte,因为这个新String对象的引用4byte刚好去填了补齐的那个坑,如果再加一个String成员,那么User类大小就直接从24byte升到32byte了,因为又产生了一个坑需要补齐。
而我们的User类中没有引入其他的类(不包括String,因为String直接被Root GC引用),所以回收User占据的内存就是回收User自身,所以Retained Heap大小等同于Shallow Heap大小。
三、tomcat中设置jvm参数
linux系统中
1.打开/tomcat_home/bin/catalina.sh文件
2.加上:JAVA_OPTS="$JAVA_OPTS -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump"
如下图位置:
注:其中不设-XX:HeapDumpPath时,dump出的文件在/tomcat_home/bin目录下
Windows系统中
1.打开/tomcat_home/bin/catalina.bat文件
2.加上:set JAVA_OPTS=%JAVA_OPTS% -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump
如下图位置:
- JVM性能调优监控工具hprof使用详解
- JVM性能调优监控工具hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- jvm 性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- JVM性能调优监控工具jps、jstack、jmap、jhat、jstat、hprof使用详解
- 爬取豆瓣美女图片网美女图片
- PHP解决多进程同时读写一个文件的问题
- 学习ORACLE Scheduler特性(9)创建Chains
- HTML初识(1)--表单提交
- - Initializing c3p0 pool... com.mchange.v2.c3p0.ComboPooledDataSourc....报错处理
- JVM性能调优监控工具hprof使用详解
- php实现内置函数以及排序
- jenkins中使用脚本来节省资源空间和使用shell提取文件名或目录名的方法
- 大龄程序员的未来在何方
- 关于Context的子类
- 独木舟上的旅行
- linux最小系统无法输入中文
- LeetCode(31)--Next Permutation
- Mysql通过IP连接授权