Runtime.exec () не завершится должным образом - PullRequest
2 голосов
/ 22 февраля 2012

Я создал WebApp, который использует внешние сценарии для сбора запросов пользователя (внутреннее программное обеспечение). Я успешно проверил WebApp с сервера Glassfish, предоставленного NetBeans, но всякий раз, когда я пытаюсь загрузить свое приложение на сторонний сервер (Apache Tomcat), я сталкиваюсь с проблемой, когда выход из процесса process.getRuntime exitValue никогда не записывается, и WebApp никогда не попадает на страницу результатов ....

Это код, который я реализовал до сих пор:

Обновление -> Код теперь работает после чтения как stderr, так и stdin:

        pd = new ProcessBuilder("runscript.bat");
        pd.redirectErrorStream(true);
        process = pd.start();


        StreamGobbler inputGobbler = new StreamGobbler(process.getInputStream(), "Input");
        StreamGobbler errorGobbler = new StreamGobbler(process.getErrorStream(),"Error");

        errorGobbler.start();
        inputGobbler.start();

        int exitVal = -1;

        try {
            exitVal = process.waitFor();
        } catch (InterruptedException ex) {
            //log Error
        }

class StreamGobbler extends Thread {
     OutputWriterReader outWR = new OutputWriterReader();
     BufferedWriter deadWriter;
     InputStream is;

// reads everything from is until empty. 
StreamGobbler(InputStream is, String type) {
    this.is = is;
    createWatch(type);
}
// depending on if Error stream or Input Stream
private void createWatch(String type){
    try {

        if(type.equals("Error"))
            deadWriter = new BufferedWriter(new FileWriter("StdError.txt"));
        else if(type.equals("Input"))
            deadWriter = new BufferedWriter(new FileWriter("StdInput.txt"));

    } catch (IOException ex) {
        //log Error
    }
}

@Override
public void run() {
    try {            
        InputStreamReader isr = new InputStreamReader(this.is);
        BufferedReader br = new BufferedReader(isr);
        String line=null;

        while ( (line = br.readLine()) != null)
            deadWriter.append(line);

        deadWriter.flush();
        deadWriter.close();

    } catch (IOException ioe) {
        //log Error
    }
}

}

Есть какие-нибудь Suggerstions? Заранее благодарен за любую помощь

1 Ответ

3 голосов
/ 22 февраля 2012

Процесс может не завершиться, когда вы вызываете exitValue () для него.

Перед вызовом process.exitValue () add: process.waitFor ();

...