我有一个在Solaris上运行的Java应用程序.该应用程序使用Runtime.exec定期启动外部进程.似乎过了一段时间,如果已经成功启动了许多此类进程,则进程的启动将挂起.此时(以及几分钟后)进行的线程转储显示java.lang.UNIXProcess.forkAndExec被“卡住了”.以下是从线程转储中获取的相关堆栈跟踪的顶部:
"Thread-85305" prio=3 tid=0x0000000102aae800 nid=0x21499 runnable [0x7fffffff2a3fe000]
java.lang.Thread.State: RUNNABLE
at java.lang.UNIXProcess.forkAndExec(Native Method)
at java.lang.UNIXProcess.<init>(Unknown Source)
at java.lang.ProcessImpl.start(Unknown Source)
at java.lang.ProcessBuilder.start(Unknown Source)
at java.lang.Runtime.exec(Unknown Source)
at java.lang.Runtime.exec(Unknown Source)
我已经阅读了一些论坛,其中一些论坛由于空间不足或内存不足而遇到了forAndExec抛出IOException的情况,但在这里我没有得到此错误.我现在正在等待获得pstack的结果,希望它可以揭示更多信息.
是否有人对如何解决此问题有任何想法?
谢谢,
麦克风
解决方法:
只要您的可执行文件在运行,线程就一直存在,也许只是挂起的外部可执行文件.
您应该尝试查找传递给可执行文件的参数,然后尝试手动启动它.