zoukankan      html  css  js  c++  java
  • jstack && jmap

    java获取内存dump的几种方式
    
    1、获取内存详情:jmap -dump:format=b,file=e.bin pid
    这种方式可以用 jvisualvm.exe 进行内存分析,或者采用 Eclipse Memory Analysis Tools (MAT)这个工具
    
    2. 获取内存dump:  jmap -histo:live pid
    这种方式会先出发fullgc,所有如果不希望触发fullgc 可以使用jmap -histo pid
    
    3.第三种方式:jdk启动加参数:
    -XX:+HeapDumpBeforeFullGC 
    -XX:HeapDumpPath=/httx/logs/dump
    这种方式会产生dump日志,再通过jvisualvm.exe 或者Eclipse Memory Analysis Tools 工具进行分析
    
    
    jstack:
    
    jstack使用教程
    
    qmq是部署在tomcat中的应用名
    -ef | grep qmq | grep -v grep
    拿到进程号, 例如上面对应的是3192
    
    第二步找出该进程内最耗费CPU的线程,可以使用ps -Lfp pid或者ps -mp pid -o THREAD, tid, time或者top -Hp pid
    例如用第三个 top -Hp 3192
    Tasks: 123 total, 0 running, 123 sleeping, 0 stopped, 0 zombie
    Cpu(s): 0.3%us, 0.4%sy, 0.0%ni, 99.3%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
    Mem: 3922688k total, 3272588k used, 650100k free, 432768k buffers
    Swap: 4194296k total, 0k used, 4194296k free, 596488k cached
    
    PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
    3494 tomcat 20 0 4905m 1.1g 11m S 0.3 28.4 0:51.91 java
    3551 tomcat 20 0 4905m 1.1g 11m S 0.3 28.4 4:46.32 java
    3588 tomcat 20 0 4905m 1.1g 11m S 0.3 28.4 0:07.35 java
    3192 tomcat 20 0 4905m 1.1g 11m S 0.0 28.4 0:00.00 java
    3194 tomcat 20 0 4905m 1.1g 11m S 0.0 28.4 0:00.82 java
    
    TIME列就是各个Java线程耗费的CPU时间,CPU时间最长的是线程ID为3551的线程,用
    "%xn" 3551
    得到ddf
    
    sudo -u tomcat jstack 3192 | grep ddf
    "New I/O worker #30" daemon prio=10 tid=0x00007f44fd525800 nid=0xde4 runnable [0x00007f4530ddf000]
    "DubboResponseTimeoutScanTimer" daemon prio=10 tid=0x00007f44fca88000 nid=0xddf waiting on condition [0x00007f45322e5000]
  • 相关阅读:
    201703-1 分蛋糕
    201812-2 小明放学
    201812-1 小明上学
    逆向_Easy_vb
    逆向_入门逆向
    代码审计_弱类型整数大小比较绕过
    代码审计_数组返回NULL绕过
    代码审计_md5()函数
    代码审计_urldecode二次编码绕过
    代码审计_extract变量覆盖
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13348654.html
Copyright © 2011-2022 走看看