`
richie.lee
  • 浏览: 29393 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

java stack trace跟踪调试

阅读更多

JDK1.5+后,有个很方便的工具jconsole跟踪jvm的stack trace,特别在多线程编程,可以方便跟踪各个线程的行踪,在发生线程阻塞或者死锁时,方便定位问题。

 

启动时,加一个参数-Dcom.sun.management.jmxremote

例如

$JAVA_HOME/bin/java -Xmx1024m  -Dcom.sun.management.jmxremote $MAIN_CLASS

 

如果是监控远程应用,修改称这样吧:

# Setup Jconsole connection
JAVA_OPTS="-Dcom.sun.management.jmxremote=true $JAVA_OPTS"
JAVA_OPTS="-Dcom.sun.management.jmxremote.port=9004 $JAVA_OPTS"
JAVA_OPTS="-Dcom.sun.management.jmxremote.authenticate=false $JAVA_OPTS"
JAVA_OPTS="-Dcom.sun.management.jmxremote.ssl=false $JAVA_OPTS"

分享到:
评论

相关推荐

    improved-android-remote-stacktrace:改进的Android远程Stacktrace库

    Android远程Stacktrace:改进 该项目是,它添加了许多重要功能: 可定制的接口,用于处理堆栈跟踪 通过将堆栈跟踪保存到自己的目录而不是应用程序的根文档目录,从而更好地处理文件系统 允许可选的调试日志记录,这...

    Java 异常的栈轨迹(Stack Trace)详解及实例代码

    Java 异常的栈轨迹(Stack Trace)是指在 Java 程序中抛出异常时,记录下异常的发生位置和调用过程的信息。这种信息对于调试和排查问题非常重要。 1.printStackTrace() 方法 printStackTrace() 方法是 Throwable ...

    java-stack-trace

    java-stack-trace是一个用于调试的java instrument,指定方法前缀,它能在指定前缀的方法被调用时打印当前堆栈。 由于asm的限制,仅支持jdk1.8及以上 编译 mvn package 用法 在java命令后添加-javaagent参数 -java...

    grepex:来自输入流的Grep独特的Java异常stacktrace

    `grepex`,正如其名,是一个针对Java异常堆栈跟踪(stacktrace)的独特工具,它允许开发者从输入流中高效地筛选出特定的异常信息。这个工具可能对于调试和监控Java应用尤其有用,因为它能快速定位到问题所在,提高...

    Stacktrace-game:初次提交

    在Java编程中,"Stacktrace"通常指的是当程序运行时遇到异常或错误时,系统自动打印出的一系列调用方法的跟踪信息。这对于调试和理解程序的执行流程至关重要。Stacktrace显示了异常发生时的函数调用顺序,帮助开发者...

    Java_用源代码片段装饰堆栈跟踪.zip

    在Java编程中,堆栈跟踪(StackTrace)是一个非常重要的概念,它可以帮助开发者了解程序运行时的执行路径,尤其是在出现异常或错误时。标题"Java_用源代码片段装饰堆栈跟踪.zip"暗示了这个压缩包可能包含了一些示例...

    Java反射之Call stack introspection详解

    StackTraceElement[] stackTrace = Thread.currentThread().getStackTrace(); for (StackTraceElement element : stackTrace) { System.out.println(element); } } public void logProblem(Throwable ...

    stun-stack:Java 眩晕堆栈

    1. **堆栈跟踪(Stack Trace)**:当Java程序运行过程中遇到异常或者通过`Thread.currentThread().getStackTrace()`方法获取时,会生成堆栈跟踪。它记录了方法调用的顺序,从最顶层的调用方法到当前执行的方法,每行...

    利用Java获取文件名、类名、方法名和行号的方法小结

    StackTraceElement[] stackTrace = new Throwable().getStackTrace(); return stackTrace[1].getLineNumber(); } ``` 这里使用`new Throwable().getStackTrace()`获取当前堆栈跟踪,由于第一个元素通常是`...

    jvm工具、参数调优&调试技巧

    - **常用命令**:`jstack pid > stacktrace.txt`。 ##### 7. VisualVM:多合一故障处理工具 - **功能**:VisualVM是一个综合性的监控和故障排除工具,支持多种视图,包括CPU使用率、内存使用情况等。 - **特性**: ...

    Java问题定位技术的文档

    其次,堆栈跟踪(Stack Trace)是另一种重要的定位手段。当Java程序抛出异常时,会打印出堆栈跟踪,显示异常发生时的方法调用顺序。这有助于我们追踪到问题的具体代码行,了解异常的起源。此外,通过JDK的`jstack`...

    java平台故障分析与诊断

    3. **堆栈跟踪**:当程序抛出异常时,堆栈跟踪(Stack Trace)会显示异常发生时执行路径上的所有方法。这有助于开发者追踪问题的来源,理解异常是如何逐层传递的。在Java中,`e.printStackTrace()`或`Thread.current...

    打印JAVA堆栈的方法

    throw new Exception("Forced exception to print stack trace"); } catch (Exception e) { e.printStackTrace(); } } ``` 这种方法的缺点在于它会打断正常的程序流,并且可能在生产环境中不适用。然而,在开发...

    JAVA JVM内存监控工具总结

    5. **jstack (Stack Trace for Java)** jstack用于生成Java线程的堆栈跟踪,帮助开发者了解线程的状态,如阻塞、等待等,有助于识别死锁和其他线程问题。 6. **JConsole** JConsole是一个图形界面工具,可以直观...

    Elipse远程调试

    4. **线程与堆栈(Threads and Stack Trace)**:在调试过程中,你可以查看当前执行的线程以及它们的堆栈信息,了解每个线程的执行状态和调用路径,这对于排查多线程问题非常有帮助。 5. **变量视图(Variables ...

    java使用DeBug以及开发者工具 快速定位系统的bug

    3. **分析堆栈跟踪**:当程序抛出异常时,通常会附带一个堆栈跟踪(stack trace),显示了异常发生时的调用链路。仔细阅读堆栈跟踪可以帮助快速定位问题根源。 4. **单元测试**:编写针对关键功能的单元测试(unit ...

    java exception

    每个异常对象都包含了异常发生时的相关信息,如异常类型、错误消息以及堆栈跟踪(StackTrace),这有助于开发者定位问题的根源。 异常的层次结构中,`Exception`类下有许多子类,如`NullPointerException`、`...

    一个简单的获取异常信息的例子,包括行号

    this.stackTrace = stackTrace; } private StackTraceElement[] stackTrace; // 其他可能的方法,如获取行号、单元名等 } ``` 通过这种方式,当`Assert`失败时,我们不仅能得到一个自定义的错误消息,还能...

    JAVA异常是否对于性能有影响.docx

    此外,异常处理过程中生成的堆栈跟踪(stack trace)对于调试和问题定位非常有用,但其收集过程却会对性能产生较大的影响。每个堆栈跟踪的收集成本可能是单纯抛出和捕获异常的10倍。当异常在多层(如库级别、框架...

    java常用英语单词(1)

    EOFException, InterruptedException, try, catch, finally, throw, throws, print Stack Trace(), get Message(), get Cause()**:异常处理相关词汇,用于捕获、处理和报告程序中的错误。 理解并熟练使用这些Java...

Global site tag (gtag.js) - Google Analytics