问题描述
项目里要实现一个功能:用java代码 Runtime.getRuntime().exec("C:\smryglclient\smryglhostmsg.exe gensn") 去执行cmd命令,并接收返回结果。一开始在我本机STS里运行时没有问题的,其它同事的机器也是正常运行。把整个web项目做成一个exe可执行程序。在测试机器上安装后执行到这段代码卡住没有反应。具体是卡到读取cmd命令的执行结果那行代码(while ((line = br.readLine()) != null))。
原因分析
- 首先排查的是环境,包括检查JDK版本,JDK相关的配置和tomcat版本。发现没有问题。排除了环境问题。
- 打开一个cmd窗口单独执行 C:\smryglclient\smryglhostmsg.exe gensn命令,没有问题。排除了exe程序本身问题。
- 在项目中打印出运行时环境相关参数,发现是使用我们exe安装程序安装的JRE,没有找错运行时环境(因为我们的测试机器以前安装过JDK)。排除了JRE环境找错的问题。
- 最后怀疑代码不健壮,捋程序代码和逻辑。发现没有问题。排除了代码问题
- 有百度了一下,Runtime.getRuntime().exec()使用的常见错误。发现有个常见错误描述和我遇到的情况一样(都是卡死)。
参考这个文章:http://www.blogjava.net/alwayscy/archive/2009/05/15/27