CMD(Java)中的Postgres Restore不再响应,而在CMD中执行相同的命令

时间:2019-08-01 20:25:35

标签: java spring postgresql

我为Windows OS任务计划程序编写了一些代码,以自动获取备份并将其本地还原到我的postgres数据库中。

所有stuf都工作到最后一步,还原命令。虽然直接在cmd shell中执行同一命令,但效果很好。

我认为我没有捕获到还原的结束,这是警告。...

有人知道为什么cmd脚本未执行并完成吗?我应该使用其他方法来关闭连接吗?

这是我的代码

                    // 7 restore database

                    ProcessBuilder processBuilder21 = new ProcessBuilder();
                    // Windows
                    String cmd1 = "pg_restore -h localhost -p " + postgresPort + " -U " + postgresUsername + " -d "
                            + postgresDbname + " " + dbLocation;

                    processBuilder21.command("cmd.exe", "/c", cmd1);
                    System.out.println(cmd1);
                    try {
                        Process process = processBuilder21.start();
                        BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream()));
                        String line;
                        while ((line = reader.readLine()) != null) {
                            System.out.println(cmd1);
                        }

                        int exitCode = process.waitFor();
                        System.out.println("Exitcode: "+ exitCode);
                        if (exitCode == 0) {
                            System.out.println("Database restored: " + postgresDbname);
                        } else {
                            System.out.println("Error database restore");
                        }
                        System.out.println(cmd1);
                    } catch (IOException e) {
                        e.printStackTrace();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }

1 个答案:

答案 0 :(得分:0)

您不是在读取命令错误输出,因此,如果生成大量错误输出,则错误流缓冲区将运行满并阻塞命令。

调用processBuilder21.redirectErrorStream(true)将命令错误输出合并到标准输出中。

其他更改:

  • 您可以组合语句。

  • 您需要关闭流,最好使用try-with-resources。

  • 您可能想更改while循环内的语句以显示line,而不是cmd1

Process process = new ProcessBuilder("cmd.exe", "/c", cmd1)
        .redirectErrorStream(true)
        .start();
try (BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream()))) {
    for (String line; (line = reader.readLine()) != null; ) {
        System.out.println(line);
    }
}
int exitCode = process.waitFor();

当然,由于您只是打印输出,因此最好通过调用inheritIO()让系统为您完成输出。

int exitCode = new ProcessBuilder("cmd.exe", "/c", cmd1)
        .inheritIO()
        .start()
        .waitFor();