我已经为 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();
}
炎炎设计
相关分类