常用JDK命令

  • **查看pid **
    pidof java
    jps -l

  • 查看类的一些信息,如字节码的版本号、常量池等。
    javap -verbose [className ]

  • 查看JVM 进程。
    jps
    jcmd -1

  • 查看进程的GC 情况。
    jstat -gcutil [pid] #显示总体情况
    jstat -gc [pid] 1000 10 #每隔1 秒刷新l 次,一共10 次

  • 查看JVM 堆内存使用状况。
    jmap -heap [pid]

  • 查看JVM 永久代使用状况。
    jmap -permstat [pid] #适用于Java 6 、7
    jmap -c lstats [pid] #Java 8 没有永久代,这里可以打印类加载器的状况

  • 查看JVM 内存中存活的对象。
    jmap -histo:live [pid]

  • 先做一次Full GC ,再dump , 只包含仍然存活的对象信息
    jcmd [PID] GC.heap_dump [FILENAME]
    jmap -dump : format=b , live , file=xxx . hprof [pid]

  • 线程dump
    jstack [pid] #-m 参数可以打印出n ative 校的信息
    jcmd [pid] Thread.print
    kill -3 [pid] (在日志文件中输出)

  • 查看JVM 启动的参数。
    jinfo -flags [pid] #查看有效参数
    jcmd [pid] VM.flags #查看所有参数

  • 查看对应参数的值。
    jinfo -flag [flagName] [pid]

  • 启用/禁止某个参数。
    jinfo -flag [+/-) [flagName) [pid)

  • 设置某个参数。
    jinfo -flag [ flagName=value] [pid)

  • 查看所有可以设置的参数以及其默认值。
    java -XX:+PrintFlagsinitial

  • 进行一次FullGC 。
    jmap -histo:live或 jmap -dump:live

上一篇:Java jmap与jcmd命令dump内存heap堆


下一篇:2021-09-16