python3.x - java調(diào)用python,python代碼自動(dòng)停止了,找不到原因
問(wèn)題描述
String[] args = {'python3', pythonFile};Process process = Runtime.getRuntime().exec(args);int exitValue = process.waitFor();BufferedInputStream in = new BufferedInputStream(process.getInputStream());BufferedInputStream err = new BufferedInputStream(process.getErrorStream());BufferedReader inBr = new BufferedReader(new InputStreamReader(in));BufferedReader errBr = new BufferedReader(new InputStreamReader(err));String lineStr;while ((lineStr = inBr.readLine()) != null) { logger.info(lineStr);}while ((lineStr = errBr.readLine()) != null) { logger.error(lineStr);}inBr.close();errBr.close();in.close();err.close();
調(diào)用python代碼,執(zhí)行時(shí)間比較長(zhǎng),估計(jì)有好幾個(gè)小時(shí),大概五六個(gè)小時(shí)。如果單獨(dú)直接在shell中執(zhí)行Python命令,則不會(huì)出問(wèn)題;但是,使用這種方式j(luò)ava調(diào)用python,就有問(wèn)題:一段時(shí)間之后,python沒(méi)有輸出了。判斷python是否正在運(yùn)行,我的方式是:不斷寫(xiě)文件,每隔一段時(shí)間,寫(xiě)文件到文件系統(tǒng)中。如果是直接shell中輸入python命令執(zhí)行,那么是正常的。java調(diào)用python,三個(gè)多小時(shí)之后,就沒(méi)有產(chǎn)生文件了,但是使用htop查看,線程還在。運(yùn)行環(huán)境是ubuntu
問(wèn)題解答
回答1:對(duì)于java和python的交互,我倒是可以給你一個(gè)思路,僅做參考。我之前做過(guò)一個(gè)項(xiàng)目,使用的是socket,手機(jī)端是java腳本,服務(wù)端是python,然后java向python服務(wù)端發(fā)送字符串進(jìn)行交互。你可以試試。
回答2:你可以去看看jython,可以在java中直接執(zhí)行python代碼
回答3:這段代碼有個(gè)問(wèn)題:
Process process = Runtime.getRuntime().exec(args);int exitValue = process.waitFor(); // A... process.getInputStream() ... // B
應(yīng)該是先處理BgetInputStream()再處理AwaitFor,因?yàn)镴ava跟它調(diào)用的程序是通過(guò)管道(pipe)通訊的,如果不及時(shí)讀取管道,被調(diào)用的程序在寫(xiě)stdout時(shí)就有可能阻塞住。
所以正確的順序是:
Process process = Runtime.getRuntime().exec(args);... process.getInputStream() ... // B... process.getErrorStream() ... // Cint exitValue = process.waitFor(); // A
另外留下個(gè)問(wèn)題:
如果被調(diào)用程序先寫(xiě)stderr再寫(xiě)stdout,不還是會(huì)阻塞嗎?Java到底應(yīng)該先讀inputStream還是先讀errorStream呢?
