gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 02:13:27 24 4
gpt4 key购买 nike

我为 Windows 操作系统任务计划程序编写了一些代码,以自动获取备份并将其本地恢复到我的 postgres 数据库。

所有的东西都在工作,直到最后一步,恢复命令。虽然直接在 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();
}

最佳答案

您没有读取命令错误输出,因此如果生成大量错误输出,错误流缓冲区将满并阻止命令。

调用 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();
<小时/>

关于java - CMD (Java) 中的 Postgres Restore 不再响应,而相同的命令在 CMD 中执行良好,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57316532/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com