首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Java8.4中如何使用ExpectJ来调用pg_dump (在PostgreSQL 8.4上)?

在Java8.4中如何使用ExpectJ来调用pg_dump (在PostgreSQL 8.4上)?
EN

Stack Overflow用户
提问于 2010-07-23 05:29:35
回答 1查看 713关注 0票数 0

我在很多地方都看到过这个问题,也就是说,从PostgreSQL以编程方式进行备份的问题。我的解决方案是使用ExpectJ,但是我无法让我的代码正常工作。

我有以下代码:

代码语言:javascript
复制
public class BackupUtility 
{
 public static void main(String[] args)
 {

  try
  {
   ExpectJ exp = new ExpectJ(20);
   Spawn shell = exp.spawn("\"C:\\Program Files\\PostgreSQL\\8.4\\bin\\pg_dump.exe\" " +
                           "-h localhost -U myUserName myDB");
   shell.expect("Password: ");
   shell.send("myPassword");

   System.out.println(shell.getCurrentStandardOutContents());

   shell.expectClose()
  }
  catch (Exception e) 
  {
   e.printStackTrace();
  }   
 }
}

然而,在shell.expect线路上,它超时了。

当我从命令提示符运行此命令时,它看起来如下所示:

C:\Documents Settings\bobjonesthe3rd>"C:\Program Files\PostgreSQL\8.4\bin\pg_dump“-h本地主机-U myUserName myDB

密码:

所以,我知道它会提示输入密码,但由于某种原因,ExpectJ没有收到提示。

任何帮助都将不胜感激。

谢谢,马特

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-07-23 13:05:07

我非常确定一种更简单的方法,不需要使用expect和send,就是通过.pgpass file。也在pg_dump docs中引用。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3313657

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档