之前的随笔提到用jstack分析java线程情况,也是在这个项目中,当线程的问题解决之后,发现程序的内存一直增长,于是用jmap工具分析了一下java程序占用内存的情况。

命令很简单,直接

jmap -histo 22955 > jmap.info

其中22955是java的pid,重定向到jmap.info文件中,其内容为:

 num     #instances         #bytes  class name
----------------------------------------------
1: 585569 359014728 [C
2: 95905 14389200 <constMethodKlass>
3: 579358 13904592 java.lang.String
4: 95905 12287600 <methodKlass>
5: 8542 10324824 <constantPoolKlass>
6: 21015 7564272 [B
7: 8542 6355376 <instanceKlassKlass>
8: 7126 5664512 <constantPoolCacheKlass>
9: 53877 5603208 com.wisdombud.unicom.monitor.po.MessageBean
10: 117112 2810688 java.util.Date
11: 46743 2534632 [Ljava.lang.Object;
12: 3669 2142176 <methodDataKlass>
13: 25046 1850544 [Ljava.util.Hashtable$Entry;
14: 51662 1653184 java.util.Hashtable$Entry
15: 50881 1628192 java.util.concurrent.ConcurrentHashMap$HashEntry
16: 43410 1389120 java.util.HashMap$Entry
17: 55516 1332384 java.util.ArrayList
18: 24915 1195920 java.util.Hashtable
19: 8988 1162184 java.lang.Class
20: 14523 1161840 java.lang.reflect.Method
21: 21461 1030128 com.sun.org.apache.xerces.internal.dom.AttrNSImpl
22: 12866 956456 [S
23: 14959 750072 [[I
24: 5752 694480 [I
25: 9667 618688 com.sun.org.apache.xerces.internal.dom.ElementNSImpl
26: 23097 554328 com.sun.org.apache.xerces.internal.dom.ParentNode$UserDataRecord
27: 13430 537200 com.sun.org.apache.xerces.internal.dom.TextImpl
28: 5279 526192 [Ljava.util.concurrent.ConcurrentHashMap$HashEntry;
29: 15795 505440 com.sun.org.apache.xerces.internal.xni.QName
30: 3120 476496 [Ljava.util.HashMap$Entry;
31: 13949 446368 com.wisdombud.unicom.collect.linux.bean.ConfLinuxFileSys
32: 23464 375424 java.lang.Object
33: 3774 366032 [Ljava.lang.String;
34: 429 233376 <objArrayKlassKlass>
35: 9685 232440 com.sun.org.apache.xerces.internal.dom.AttributeMap
36: 6981 223392 com.wisdombud.unicom.collect.linux.bean.PerfLinuxFileSys
37: 4652 223296 java.util.HashMap
38: 5279 211160 java.util.concurrent.ConcurrentHashMap$Segment
39: 5512 176384 java.util.concurrent.locks.ReentrantLock$NonfairSync
40: 243 173016 [Lcom.sun.org.apache.xerces.internal.util.SymbolTable$Entry;
41: 3159 126360 java.lang.ref.SoftReference
42: 2516 120768 com.wisdombud.unicom.collect.linux.bean.ConfLinux
43: 2761 110440 java.util.LinkedHashMap$Entry
44: 1143 100584 org.snmp4j.Snmp$PendingRequest
45: 1364 98208 org.snmp4j.mp.StateReference
46: 2352 94080 com.wisdombud.unicom.collect.linux.bean.PerfLinux Total 2225122 467913224

我去掉了很多占用比较小类。

最重要的是后两列,第三列是占用的字节数,第四列是类,关于类,解释如下:

  • [C is a char[]
  • [S is a short[]
  • [I is a int[]
  • [B is a byte[]
  • [[I is a int[][]

参考:http://stackoverflow.com/questions/7913759/what-are-these-objects-in-the-jmap-histogram

可以看到,char比较多,但也能定位到自己代码中MessageBean占用比较多,迅速定位到操作此类的方法,在通过分析代码,找到了问题的原因。

jmap可以经常用,比如每10分钟运行一次,通过对比,观察哪些类的占用内存增长比较多。

另外,jmap还有dump的参数,其方法如下:

jmap -dump:format=b,file=mem.dat 22955

在这个项目中,dump出来的文件非常大,因为网络的原因没有传过来,所以没有分析。

关于dump的用法,可以参考:http://www.cnblogs.com/ggjucheng/archive/2013/04/16/3024986.html

用jmap分析java程序的更多相关文章

  1. jvm 命令使用调优 通过jstat、jmap对java程序进行性能调优

    转载:http://blog.csdn.net/jerry024/article/details/8507589 转载: https://blog.csdn.net/zhaozheng7758/art ...

  2. 利用jdk自带的运行监控工具JConsole观察分析Java程序的运行

    利用jdk自带的运行监控工具JConsole观察分析Java程序的运行 原文链接 一.JConsole是什么 从Java 5开始 引入了 JConsole.JConsole 是一个内置 Java 性能 ...

  3. 如何利用JConsole观察分析Java程序的运行并进行排错调优_java

    如何利用JConsole观察分析Java程序的运行并进行排错调优_java 官方指导  use jconsole use jmx technology

  4. 如何利用 JConsole观察分析Java程序的运行,进行排错调优

    原文链接:http://jiajun.iteye.com/blog/810150 一.JConsole是什么 从Java 5开始 引入了 JConsole.JConsole 是一个内置 Java 性能 ...

  5. linux下分析Java程序内存汇总

    使用pmap查看进程内存 执行命令 使用pmap能够查看某一个进程(非java的也能够)的内存使用使用情况, 命令格式: pmap 进程id 演示样例说明 比如执行: pmap 12358 显示结果例 ...

  6. JDK自带的运行监控工具JConsole观察分析Java程序的运行

    原文地址:https://blog.csdn.net/libaolin198706231987/article/details/55057149 一.JConsole是什么 从Java 5开始 引入了 ...

  7. 如何利用JConsole观察分析JAVA程序的运行

    今天在CSDN看到一朋友说关于对JVM的研究,正好看到有关于jconsole的文章,特意找了下资料,留着备用 ps:jconsole建议用JDK1.6的1.5的界面太简陋了,另外还有增强版jvisua ...

  8. 使用JConsole观察分析Java程序的运行(转)

    一.JConsole是什么 从Java 5开始 引入了JConsole.JConsole是一个内置Java性能分析器,可以从命令行或在GUI shell中运行.您可以轻松地使用JConsole(或者, ...

  9. linux下分析java程序占用CPU、内存过高

    一.CPU过高分析 1)使用TOP命令查看CPU.内存使用状态可以发现CPU占用主要分为两部分,一部分为系统内核空间占用CPU百分比,一部分为用户空间占用CPU百分比.其中CPU状态中标示id的为空闲 ...

随机推荐

  1. Spring事务报Connection is read-only

    昨天做项目时,写了个方法,程序突然报了Connection is readonly. Queries leading to data modification are not allowed调了程序半 ...

  2. Android中使用ListView实现分页刷新(线程休眠模拟)(滑动加载列表)

    当要显示的数据过多时,为了更好的提升用户感知,在很多APP中都会使用分页刷新显示,比如浏览新闻,向下滑动到当前ListView的最后一条信息(item)时,会提示刷新加载,然后加载更新后的内容.此过程 ...

  3. HDU 2176 (Nim博弈 先手取胜方案) 取(m堆)石子游戏

    切切水题,放松心情:-D #include <cstdio> + ; int a[maxn]; int main() { //freopen("in.txt", &qu ...

  4. HDU 1372 Knight Moves【BFS】

    题意:给出8*8的棋盘,给出起点和终点,问最少走几步到达终点. 因为骑士的走法和马的走法是一样的,走日字形(四个象限的横竖的日字形) 另外字母转换成坐标的时候仔细一点(因为这个WA了两次---@_@) ...

  5. JS改变input的value值不触发onchange事件解决方案 (转)

    方法(一)(转载的网络资料) 需要了解的知识     首先,我们需要了解onchange和onpropertychange的不同: IE下,当一个HTML元素的属性改变的时候,都能通过 onprope ...

  6. BZOJ 2429 聪明的猴子

    kruskal. #include<iostream> #include<cstdio> #include<cstring> #include<algorit ...

  7. HDU 整除的尾数 2099

    解题思路:很简单的一道水题,这几天比较忙,没怎么刷题,找找自信,很快1A.   还可以,嘿嘿 #include<cstdio> #include<cstring> #inclu ...

  8. Android Lock Screen Orientation

    一些与屏幕有关的基础知识: //这个是手机屏幕的旋转角度 final int rotation = this.getWindowManager().getDefaultDisplay().getOri ...

  9. app如何节省流量

    前言:“客户端上传时间戳”的玩法,你玩过么?一起聊聊时间戳的奇技淫巧! 缘起:无线时代,流量敏感.APP在登录后,往往要向服务器同步非常多的数据,很费流量,技术上有没有节省流量的方法呢?这是本文要讨论 ...

  10. 性能测试之LoardRunner 测试场景监控关注的几点

    1.系统业务处理能力,即通常我们在进行性能测试的时候,在特定的硬件和软件环境下考察的业务处理能力,即“事物”,需要关注当前.平时.峰值以及长远未来业务发展情况,考虑不同业务的处理数量,从而设定相应的业 ...