[英]Calling Python from Java (Tomcat6) as sub-process
我正在尝试从java / tomcat6 webapp调用python脚本。 我目前正在使用以下代码:
Process p = Runtime.getRuntime().exec("python <file.py>");
InputStream in = p.getInputStream();
InputStreamReader isr = new InputStreamReader(in);
BufferedReader b = new BufferedReader(isr);
logger.info("PYTHON OUTPUT");
String line = null;
while ( (line = b.readLine()) != null){
logger.info(line);
}
p.waitFor();
logger.info("COMPLETE PYTHON OUTPUT");
logger.info("EXIT VALUE: "+p.exitValue());
我真的看不到python脚本在catalinia.out文件中的任何输出,并且无法使用像jython这样的适配器库,因为该脚本依赖于多个需要python的Numpy模块才能工作的机器学习库。
救命?
可能是以下一种(或多种)解释:
该命令失败并将错误消息写入您未查看的“ stderr” fd...。
由于命令名称不正确,导致命令无法启动; 例如,在$PATH
上找不到它。
该命令正尝试从其stdin
fd中读取...,但您尚未提供任何输入。
命令行拆分可能是一个问题; 例如,如果您使用带有嵌入式空格的路径名,或其他通常由外壳程序处理的东西。
另外,由于这是python,因此这可能是python特定的环境变量,当前目录和/或正在执行命令的有效用户的问题。
如何进行:
确定python命令是否实际上正在启动。 例如。 “ hack”“”,以便在启动时将一些内容写入临时文件。
更改为使用ProcessBuilder
创建Process
对象。 这将使您对流及其处理方式有更多的控制。
找出要发送给子进程“ stderr”的内容。 (ProcessBuilder允许您将其重定向到“ stdout” ...)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.