如何使用kill -3 <pid>命令</pid>每30秒进行一次java堆转储

时间:2012-07-26 12:35:07

标签: java shell heap dump

请帮忙,我想运行一个shell脚本,它应该使用kill -3命令每30秒进行一次jave堆转储。提前谢谢。

4 个答案:

答案 0 :(得分:7)

您是否尝试过这么简单的shell脚本?

while true
do
  jmap -dump:file=/tmp/java-`date +%s`.hprof PID_OF_JVM
  sleep 30
done

这将为每个快照创建一个文件梨。对于线程转储,您可以使用类似的脚本:

while true
do
  jstack PID_OF_JVM > stack-`date +%s`.txt
  sleep 30
done

我猜您可以使用kill -3代替jstack

答案 1 :(得分:4)

你可以使用像这样的代码从java应用程序进行线程转储

 public static String getDumpFor(Thread thread) {
    StringBuilder sb = new StringBuilder();
    if (thread.isAlive()) {
        StackTraceElement[] stackTrace = thread.getStackTrace();
        sb.append(thread.toString()).append("\n")
                .append(String.format(" State - %s,", thread.getState()))
                .append(String.format(" Is daemon = %s,", thread.isDaemon()));
        for (StackTraceElement s : stackTrace)
            sb.append("\tat ").append(s.getClassName()).append(".").append(s.getMethodName()).append("(").append(s.getFileName()).append(":").append(s.getLineNumber()).append(")")
                    .append("\n");
    }
    return sb.toString();
}


public static void dumpActiveThreads() {
    Map<Thread, StackTraceElement[]> stackTraces = Thread.getAllStackTraces();
    Set<Thread> keySet = stackTraces.keySet();
    System.out.println("\nThread dump begin:");
    for (Thread thread : keySet)
        dumpActiveThread(thread);
    System.out.println("\nThread dump end.");

}

然后像这样安排任务

 final ScheduledFuture<?> scheduledFuture = scheduledExecutorService.scheduleWithFixedDelay(
            new Runnable() {dumpActiveThreads()},
            0,
            30, TimeUnit.SECONDS);

答案 2 :(得分:1)

我没有使用kill -3命令,但我使用了jmap提供的sun sdk命令

您可以编写脚本,然后在脚本中运行命令。

${JAVA_HOME}/bin/jmap -dump:file=/home/MyDump.hprof PID

答案 3 :(得分:0)

3只会给出线程转储而不是堆dump.Thread转储意味着你只能检查JVM中每个线程的堆栈跟踪。但是你在linux上查看堆转储然后需要使用下面的命令。 jmap -dump:file = myheap.bin {pid,你正在寻找堆转储}。输出“myheap.bin”不是人类可读的,要读取文件就可以使用MAT工具。 MAT下载链接:http://www.eclipse.org/mat/