Java自带虚拟机工具

1 jps:虚拟机进程状况工具

-q 只显示pid,不显示class名称,jar文件名和传递给main方法的参数

$>  jps -q

24650

18743

-m 输出传递给main方法的参数,在嵌入式jvm上可能是null

9248 Jps -m
17368

-l 输出应用程序main class的完整package名或者应用程序的jar文件完整路径名

$> jps -l

17316 sun.tools.jps.Jps
17368

-v 输出传递给JVM的参数

$> jps -v

17368 -Dosgi.requiredJavaVersion=1.8 -Dosgi.instance.area.default=@user.home/eclipse-workspace -XX:+UseG1GC -XX:+UseStringDeduplication -Dosgi.requiredJavaVersion=1.8 -Dosgi.dataAreaRequiresExplicitInit=true -Xms256m -Xmx1024m
22680 Jps -Denv.class.path=,;%JAVA_HOME\lib% -Dapplication.home=D:\DevelopSoft\java\jdk1.8 -Xms8m

-V 隐藏输出传递给JVM的参数

$> jps -V

 

2 jstat:虚拟机统计信息监视工具

    jstat命令格式为:  jstat [ option vmid [interval[s|ms] [count]] ]

    如果是本地虚拟机进程,VMID与LVMID 是一致的;如果是远程虚拟机进程,那VMID的格式应当是:

           [protocol:][//]lvmid[@hostname[:port]/servername]

    参数interval和count代表查询间隔和次数,如果省略这2个参数,说明只查询一次。

           

 

 

           表示查询 15620的gc情况,1000毫秒一次,查询5次。

    选项option代表用户希望查询的虚拟机信息,主要分为三类:类加载、垃圾收集、运行期编译状况。

                                                                                     详细参数表

          

 

3 jinfo:Java配置信息工具

    jinfo(Configuration Info for Java)的作用是实时查看和调整虚拟机各项参数。

 

    jinfo命令格式:

    Usage:
    jinfo [option] <pid>
    (to connect to running process)
    jinfo [option] <executable <core>
    (to connect to a core file)
    jinfo [option] [server_id@]<remote server IP or hostname>
    (to connect to remote debug server)

    where <option> is one of:
    -flag <name> to print the value of the named VM flag
    -flag [+|-]<name> to enable or disable the named VM flag
    -flag <name>=<value> to set the named VM flag to the given value
    -flags to print VM flags
    -sysprops to print Java system properties
    <no option> to print both of the above
    -h | -help to print this help message

    常用:jinfo [ option ] pid

 

4 jmap:Java内存映像工具    

    jmap(Memory Map for Java)命令用于生成堆转储快照(一般称为heapdump或dump文件)。

    如果不使用jmap命令,要想获取Java堆转储快照也还有一些比较“暴力”的手段:XX:+HeapDumpOnOutOfMemoryError参数,可以让虚拟机在内存溢出异常出现之后自动生成堆转储 快照文件,通过-XX:+HeapDumpOnCtrlBreak参数则可以使用[Ctrl]+[Break]键让虚拟 机生成堆转储快 照文件,又或者在Linux系统下通过Kill-3命令发送进程退出信号“恐吓”一下虚拟机,也能顺利拿到堆转 储快照。
    jmap的作用并不仅仅是为了获取堆转储快照,它还可以查询finalize执行队列、Java堆和方法区的 详细信息,如空间使用率、当前用的是哪种收集器等。 和jinfo命令一样,jmap有部分功能在Windows平台下是受限的,除了生成堆转储快照的-dump选项和用于查看每个类的实例、空间占用统计的-histo选项在所有操作系统中都可以使用之外,其余选项都 只能在Linux/Solaris中使用。

    jmap命令格式:jmap [ option ] vmid

 

 

 

 

 

5 jhat:虚拟机堆转储快照分析工具

    JDK提供jhat(JVM Heap Analysis Tool)命令与jmap搭配使用,来分析jmap生成的堆转储快照。相对简陋,不常使用。

    屏幕显示“Server is ready.”的提示后,用户在浏览器中输入http://localhost:7000/可以看到分析结果。

 

6 jstack:Java堆栈跟踪工具

    jstack(Stack Trace for Java)命令用于生成虚拟机当前时刻的线程快照(一般称为threaddump或者javacore文件)。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的 目的通常是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间挂 起等,都是导致线程长时间停顿的常见原因。线程出现停顿时通过jstack来查看各个线程的调用堆栈, 就可以获知没有响应的线程到底在后台做些什么事情,或者等待着什么资源。

    jstack命令格式:jstack [ option ] pid

  

    

    从JDK 5起,java.lang.Thread类新增了一个getAllStackTraces()方法用于获取虚拟机中所有线程的StackTraceElement对象。使用这个方法可以通过简单的几行代码完成jstack的大部分功能,在实际项目 中不妨调用这个方法做个管理员页面,可以随时使用浏览器来查看线程堆栈。

 

posted @ 2021-01-21 21:00  学不动了orz  阅读(122)  评论(0)    收藏  举报