词条 | ThreadDump |
释义 | 什么是Thread Dump?Thread Dump是非常有用的诊断Java应用问题的工具,每一个Java虚拟机都有及时生成显示所有线程在某一点状态的thread-dump的能力。虽然各个 Java虚拟机thread dump打印输出格式上略微有一些不同,但是Thread dumps出来的信息包含线程;线程的运行状态、标识和调用的堆栈;调用的堆栈包含完整的类名,所执行的方法,如果可能的话还有源代码的行数。 Thread Dump特点1. 能在各种操作系统下使用 2. 能在各种Java应用服务器下使用 3. 可以在生产环境下使用而不影响系统的性能 4. 可以将问题直接定位到应用程序的代码行上 Thread Dump能诊断的问题1. 查找内存泄露,常见的是程序里load大量的数据到缓存 2. 发现死锁线程 SUN JVM 产生ThreadDump1. Solaris OS<ctrl>-’\\’ (Control-Backslash) kill -QUIT <PID> 2. HP-UX/UNIX/LinuxKill -3 <PID> 3.Window直接对MSDOS窗口的程序按Ctrl-break 有些Java应用服务器是在控制台上运行,如Weblogic,为了方便获取threaddump信息,在weblogic启动的时候,会将其标准输出重定向到一个文件,用"nohup ./startWebLogic .sh > log.out &"命令,执行"kill -3 <pid>",Thread dump就会输出到log.out里。Tomcat的Thread Dump会输出到命令行控制台或者logs的catalina.out文件里。为了反映线程状态的动态变化,需要接连做三次以上thread dump,每次间隔10-20s。 IBM JVM 产生Thread Dump在AIX上用IBM的JVM,内存溢出时默认地会产生javacore文件(关于cpu的)和heapdump文件(关于内存的)。 如果没有,则参照下列方法: 1. 在server启动前设置下面环境变量(可以加在启动脚本中) export IBM_HEAPDUMP=true export IBM_HEAP_DUMP=true export IBM_HEAPDUMP_OUTOFMEMORY=true export IBM_HEAPDUMPDIR=<directory path> 2. 用set命令检查参数设置,确保没有设置DISABLE_JAVADUMP,然后启动server 3. 执行kill -3 <PID>命令可以生成javacore文件和heapdump文件 常见线程状态IBM JVM常见线程状态在IBM JVM产生的javacore或者Threaddump文件中 Idle线程:一个已经准备好接受请求的线程,但是没有和插件或者客户端建立连接 Keep-Alive线程:是一个已经准备好接受请求的线程,并且已经和插件或者客户端建立连接 正在接受请求的线程:是一个线程正在读取request的内容或者头部 Sun JVM的常见线程状态对于thread dump信息,主要关注的是线程的状态和其执行堆栈 线程的状态一般为三类 Runnable(R):当前可以运行的线程 Waiting on monitor(CW):线程主动wait Waiting for monitor entry(MW):线程等锁 一般关注的都是第一和第三种状态的线程 Cpu很忙则关注runnable的线程 Cpu闲则关注waiting for monitor entry的线程 一种典型的死锁是由于在server端应用(比如servlet)中请求由同一weblogic实例server的资源,解决办法就是将该servlet放到另外的执行队列里去执行 。 |
随便看 |
百科全书收录4421916条中文百科知识,基本涵盖了大多数领域的百科知识,是一部内容开放、自由的电子版百科全书。