深入Java虚拟机(五):常用虚拟机工具

 

JDK的bin目录下有很多常用的工具,包括:

jps:显示系统中所有Hotspot虚拟机进程

jstat:收集Hotspot虚拟机各方面运行数据

jinfo:显示虚拟机的配置信息

jmap:用于生成虚拟机的内存快照信息

jhat:用于分析heapdump文件

jstack:显示虚拟机的线程栈信息

此外还有可视化工具Jconsole和VisualVM

执行示例: 
$ jps -l 
3733 sun.tools.jps.Jps 
3700 com.leanworld.JVMTools
 

$ jstat -gcutil 3700 500 4 
  S0     S1     E      O      P     YGC     YGCT    FGC    FGCT     GCT   
50.00   0.00  60.78   0.50  12.76    214    0.049     0    0.000    0.049 
  0.00  25.00  20.27   0.50  12.76    215    0.049     0    0.000    0.049 
  0.00  25.00  70.91   0.50  12.76    215    0.049     0    0.000    0.049 
50.00   0.00  20.27   0.50  12.76    216    0.049     0    0.000    0.049 

$ jstack 3700 
2012-01-30 16:36:05 
Full thread dump Java HotSpot(TM) Server VM (17.0-b16 mixed mode): 

"Attach Listener" daemon prio=10 tid=0xaca16c00 nid=0x1384 waiting on condition [0x00000000] 
   java.lang.Thread.State: RUNNABLE 

"Low Memory Detector" daemon prio=10 tid=0xaca00c00 nid=0x1366 runnable [0x00000000] 
   java.lang.Thread.State: RUNNABLE 

 

$jinfo 3700 
Attaching to process ID 5081, please wait... 
Debugger attached successfully. 
Server compiler detected. 
JVM version is 17.0-b16 
Java System Properties: 

java.runtime.name = Java(TM) SE Runtime Environment 
sun.boot.library.path = /home/learnworld/software/jdk1.6.0_21/jre/lib/i386 
java.vm.version = 17.0-b16 
java.vm.vendor = Sun Microsystems Inc. 
java.vendor.url = http://java.sun.com/ 
......

$ jmap -dump:format=b,file=dump.tmp 3700 
Dumping heap to /home/learnworld/dump.tmp ... 
Heap dump file created
 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值