草庐IT

thread-dump

全部标签

java - Thread.sleep() 永不返回

我在使用Java上的Thread.sleep()时遇到了一个奇怪的错误。出于某种原因,当我在某些机器上调用sleep时,它永远不会返回。我无法弄清楚可能导致这种行为的原因。起初,我认为错误可能在我的代码中的其他地方,所以我做了最简单的sleep测试:publicclassSleepTest{publicstaticvoidmain(String[]args){System.out.println("Beforesleep...");try{Thread.sleep(100);}catch(InterruptedExceptione){}System.out.println("After

java - Thread.sleep() 挂起?

这是我的简单代码,每秒循环一次(不需要精确)并在必要时开始工作:while(true){//checkdbfornewjobsand//kickoffthreadifnecessarytry{Thread.sleep(1000);}catch(Throwablet){LOG.error("",t);}}这段代码已经运行了好几个月。就在昨天,我们开始遇到问题,我们的一台服务器似乎卡在Thread.sleep(1000)方法中。IOW-已经过去一天了,Thread.sleep还没有返回。我启动了jconsole并获取了有关该线程的信息。Name:Thread-3State:TIMED_WA

java - Thread.sleep() 挂起?

这是我的简单代码,每秒循环一次(不需要精确)并在必要时开始工作:while(true){//checkdbfornewjobsand//kickoffthreadifnecessarytry{Thread.sleep(1000);}catch(Throwablet){LOG.error("",t);}}这段代码已经运行了好几个月。就在昨天,我们开始遇到问题,我们的一台服务器似乎卡在Thread.sleep(1000)方法中。IOW-已经过去一天了,Thread.sleep还没有返回。我启动了jconsole并获取了有关该线程的信息。Name:Thread-3State:TIMED_WA

Java 线程转储 : BLOCKED thread without "waiting to lock ..."

我很难理解从jstack获得的线程转储,用于在Tomcat6(java1.6.0_22,Linux)上运行的SpringMVCWeb应用程序。我看到自己被阻塞的阻塞线程(导致其他线程等待),但是线程转储并没有告诉我他们等待的原因或等待哪个监视器。例子:"TP-Processor75"daemonprio=10tid=0x00007f3e88448800nid=0x56f5waitingformonitorentry[0x00000000472bc000]java.lang.Thread.State:BLOCKED(onobjectmonitor)atjava.lang.Class.in

Java 线程转储 : BLOCKED thread without "waiting to lock ..."

我很难理解从jstack获得的线程转储,用于在Tomcat6(java1.6.0_22,Linux)上运行的SpringMVCWeb应用程序。我看到自己被阻塞的阻塞线程(导致其他线程等待),但是线程转储并没有告诉我他们等待的原因或等待哪个监视器。例子:"TP-Processor75"daemonprio=10tid=0x00007f3e88448800nid=0x56f5waitingformonitorentry[0x00000000472bc000]java.lang.Thread.State:BLOCKED(onobjectmonitor)atjava.lang.Class.in

java - Tomcat 线程转储

是否可以从Tomcat中获取线程转储?我想在某个时间点监控Tomcat中运行的线程。注意:我在Web逻辑上这样做,但我不知道如何在Tomcat上完成。 最佳答案 如果您使用Linux,您可以发送kill-3[您的tomcat的pid],它将转储catalina.out中的所有当前线程。 关于java-Tomcat线程转储,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/185734

java - Tomcat 线程转储

是否可以从Tomcat中获取线程转储?我想在某个时间点监控Tomcat中运行的线程。注意:我在Web逻辑上这样做,但我不知道如何在Tomcat上完成。 最佳答案 如果您使用Linux,您可以发送kill-3[您的tomcat的pid],它将转储catalina.out中的所有当前线程。 关于java-Tomcat线程转储,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/185734

java - Thread.sleep() 在 while 循环中

我注意到NetBeans警告我在我的Java代码中的while循环中使用Thread.sleep(),所以我对这个主题进行了一些研究。主要问题似乎是性能之一,当计数器仍在hibernate时,您的while条件可能会变为真,从而在等待下一次迭代时浪费挂钟时间。这一切都说得通。我的应用程序需要联系远程系统并定期轮询操作的状态,等待操作完成后再发送下一个请求。目前代码在逻辑上是这样做的:Stringstate=getstateviaRPCcallwhile(!state.equals("complete")){Thread.sleep(10000);//Wait10secondsstate

java - Thread.sleep() 在 while 循环中

我注意到NetBeans警告我在我的Java代码中的while循环中使用Thread.sleep(),所以我对这个主题进行了一些研究。主要问题似乎是性能之一,当计数器仍在hibernate时,您的while条件可能会变为真,从而在等待下一次迭代时浪费挂钟时间。这一切都说得通。我的应用程序需要联系远程系统并定期轮询操作的状态,等待操作完成后再发送下一个请求。目前代码在逻辑上是这样做的:Stringstate=getstateviaRPCcallwhile(!state.equals("complete")){Thread.sleep(10000);//Wait10secondsstate

java - 了解引用处理程序线程

我将继续深入了解Java线程。不幸的是,我的Java认证没有涵盖这部分,所以学习的唯一方法是发布一系列愚蠢的问题。经过这么多年的Java开发,我有时想知道我还需要学习多少:-)我现在特别注意引用处理程序线程。"ReferenceHandler"daemonprio=10tid=0x02da3400nid=0xb98inObject.wait()[0x0302f000]java.lang.Thread.State:WAITING(onobjectmonitor)atjava.lang.Object.wait(NativeMethod)-waitingon(ajava.lang.ref.R