Sun SDK 监控和故障处理工具

 

名称功能
jpsJVM Process Status Tool ,显示指定系统内所有的HotSpot虚拟机进程
jstat JVM Statistics Monitoring Tool ,用于收集HotSpot虚拟机各方面的运行数据
jinfoConfiguration Info for Java , 显示虚拟机配置信息
jmap Memory Map for Java,生成虚拟机的内存转储快照(heapdump文件)
jhat JVM Heap Dump Browser ,建立http服务器,分析dump文件,并在浏览器中查看
jstackStack Trace for Java ,显示虚拟机的快照

jps

jps:虚拟机进程状态工具,例:

jps -l

jps通过RMI协议查询开启了RMI服务的远程虚拟机进程状态

 

jstat

监控虚拟机各种状态信息,例:

jstat -gc 1234 1000 10

查询指定进程id(可以通过jps查看)1234,每1000毫秒GC情况,共执行10次

 

jinfo

实时查看和调整虚拟机的各项参数,例:

jinfo -flag PrintGC 45224

 

jmap 

java内存映射工具,生成堆栈转储快照,不适用jmap命令,可以通过

-XX:+HeapDumpOnOutOfMemoryError

让虚拟机在OOM出现后,自动生成dump文件,并通过

-XX:HeapDumpPath=/path/logs/

指定dump文件的生成目录,

 

-XX:+HeapDumpOnCtrlBreak

通过ctrl+break组合键让虚拟机生成dump文件,

通过完成命令,生成dump文件,例:

jmap -dump:live format=b,file=/path/logs/heapdump.bin 1234

其中自参数live表示只查看存活对象,1234是通过jps查看到的id

 

jhat

dump快照分析工具

jhat -port 5000 /path/logs/heapdump.bin

指定http端口,并将分析结果通过http服务器,在浏览器中查看,其中Heap Histogram(类似 jmap -histo)是内存泄漏问题的主要集中点,不建议在生产环境中直接运行命令进行dump文件分析,因为分析过程可能会占用大量的系统资源,另外一个分析工具 visualVM。

 

jstack

生产虚拟机当前线程的快照(threaddump)

jstack -l 1234

查看指定线程1234堆栈情况,分析线程长时间停留的原因,如线程间死锁,资源等待,停顿。可以通过jstack追踪问题。

 

tips:

1) java.lang.Thread 类在1.5以后,新增getAllStackTraces()方法,用于获取虚拟机所有线程的StackTraceElement对象,通过该方法完成jstack的大部分功能,实际应用可以通过此方法生成一个简单的jsp页面,查看监控实时信息:


<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@page import="java.util.Map" %>
<html>
<head>
    <title>jstack monitor</title>
</head>
<body>

<pre>
    <% 
        for(Map.Entry<Thread,StackTraceElement[]> stackTrace : Thread.getAllStackTraces().entrySet()){
            Thread thread = (Thread) stackTrace.getKey();
            StackTraceElement[] stack = (StackTraceElement[]) stackTrace.getValue();
            if(thread.equals(Thread.currentThread())){
                continue;
            }
            out.println("\n 线程:" + thread.getName() + "\n");
            for(StackTraceElement element : stack){
                out.println("\t" + element + "\n");
            }
        }
    %>
    
</pre>
</body>
</html>

 

转载于:https://my.oschina.net/runforfuture/blog/918823

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值