1、Jps:虚拟机进程状况工具
列出正在运行的虚拟机进程,并显示虚拟机执行主类(Main class 函数所在的类)的名称以及这些进程的本地虚拟机唯一ID(LVMID)
jps [options] [hostid]
jps可以通过RMI协议查询开启了RMI服务的远程虚拟机进程状态,hostid就是RMI注册表中注册的主机名。
选项 | 作用 | 示例 |
---|---|---|
-q | 只输出LVMID,省略主类的名称 | |
-m | 输出虚拟机进程启动时候传递给朱磊main()函数的参数 |
|
-l | 输出主类的全名,如果进程执行的是Jar包,输出Jar路径 | |
-v | 输出虚拟机进程启动时JVM参数 |
|
2、 jstat: 虚拟机统计信息监视工具
用于监视虚拟机各种运行状态信息的命令工具 ,它可以 显示本地或者远程虚拟机中的 类装载、内存、垃圾收集、JIT编译等运行数据
jstat 命令格式
jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
如果 是本地虚拟机进程,则vmid跟LVMID一致,如果是远程虚拟机,则VMID的格式应当是:
[protocol:][//] lvmid[@hostname[:port]/servername]
interval 和 count表示 查询间隔和次数,如果省略这两个参数,则只查一次
参数解释:
option 可以从下面参数中选择
-class 显示ClassLoad的相关信息;
-compiler 显示JIT编译的相关信息;
-gc 显示和gc相关的堆信息;
-gccapacity 显示各个代的容量以及使用情况;
-gccause 显示垃圾回收的相关信息(通-gcutil),同时显示最后一次或当前正在发生的垃圾回收的诱因;
-gcnew 显示新生代信息;
-gcnewcapacity 显示新生代大小和使用情况;
-gcold 显示老年代和永久代的信息;
-gcoldcapacity 显示老年代的大小;
-gcpermcapacity 显示永久代的大小;
-gcutil 显示垃圾收集信息;
-printcompilation输出JIT编译的方法信息;
-t 可以在打印的列加上Timestamp列,用于显示系统运行的时间
-h 可以在周期性数据数据的时候,可以在指定输出多少行以后输出一次表头
interval 执行每次的间隔时间,单位为毫秒
count 用于指定输出多少次记录,缺省则会一直打印
例如:每250毫秒查询一次进程2746垃圾收集状况,一共查询20次,那么命令是
jstat -gc 2746 250 20
3、jmap:Java内存映像工具
jmap用于生成堆转储快照,还可以查询finalize执行队列、Java堆和永久代的详细信息,如空间使用率、当前使用哪种收集器等;
jmap [option] <pid>
(to connect to running process)
jmap [option] <executable <core>
(to connect to a core file)
jmap [option] [server_id@]<remote server IP or hostname>
(to connect to remote debug server)
基本参数:
-dump:[live,]format=b,file=<filename> 使用hprof二进制形式,输出jvm的heap内容到文件=. live子选项是可选的,假如指定live选项,那么只输出活的对象到文件.
-finalizerinfo 打印正等候回收的对象的信息.
-heap 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况.
-histo[:live] 打印每个class的实例数目,内存占用,类全名信息. VM的内部类名字开头会加上前缀”*”. 如果live子参数加上后,只统计活的对象数量.
-permstat 打印classload和jvm heap长久层的信息. 包含每个classloader的名字,活泼性,地址,父classloader和加载的class数量. 另外,内部String的数量和占用内存数也会打印出来.
-F 强迫.在pid没有相应的时候使用-dump或者-histo参数. 在这个模式下,live子参数无效.
-h | -help 打印辅助信息
-J 传递参数给jmap启动的jvm.
pid 需要被打印配相信息的java进程id,创业与打工的区别 - 博文预览,可以用jps查问.
例如 生成快照
jmap -dump:format=b,file=dumpfiletest.txt -F 39182
由于在我没有 加 -F 的时候失败了
39182: Unable to open socket file: target process not responding or HotSpot VM not loaded
The -F option can be used when the target process is not responding
所以加上-F强制他生成快照了;
4、jhat:虚拟机堆转储快照分析工具
jhat与jmap搭配使用,jhat分析jmap生成的堆转储快照,jhat内置一个微型的http/html服务器,分析dump结果后可以在浏览器中查看,已过一般不会用这个来分析,也不会在当前服务器分析,一般都是讲dump文件转储到另外一台专门的服务器去分析文件
例如:分析jmap生成的dump文件
jhat dumpfiletest.txt
然后打开浏览器访问 127.0.0.1:7000
5、Jstack :Java堆栈跟踪工具
jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项"-J-d64",Windows的jstack使用方式只支持以下的这种方式:
jstack [-l] pid
如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题。另外,jstack工具还可以附属到正在运行的java程序中,看到当时运行的java程序的java stack和native stack的信息, 如果现在运行的java程序呈现hung的状态,jstack是非常有用的。
命令格式
jstack [ option ] pid
jstack [ option ] executable core
jstack [ option ] [server-id@]remote-hostname-or-IP
常用参数
1)、options:
executable Java executable from which the core dump was produced.
(可能是产生core dump的java可执行程序)
core 将被打印信息的core dump文件
remote-hostname-or-IP 远程debug服务的主机名或ip
server-id 唯一id,假如一台主机上多个远程debug服务
2)、基本参数:
-F当’jstack [-l] pid’没有相应的时候强制打印栈信息
-l长列表. 打印关于锁的附加信息,例如属于java.util.concurrent的ownable synchronizers列表.
-m打印java和native c/c++框架的所有栈信息.
-h | -help打印帮助信息
pid 需要被打印配置信息的java进程id,可以用jps查询.