1

我有一个非常简单的 ruby​​ 脚本,如下所示:

puts "Running test program"
ENV["TEST"] = "foo"
puts ENV["TEST"]

当我从命令行运行此脚本时,它按预期工作:

C:\Temp\rb-test>ruby foo.rb
Running test program
foo

我需要做的是从 Java 程序启动这个脚本。Java 程序如下所示:

Path path = FileSystems.getDefault().getPath("c:", "temp", "rb-test");
ProcessBuilder pb = new ProcessBuilder("ruby.exe", "foo.rb").directory(path.toFile()).redirectErrorStream(true);
Process process = pb.start();
process.waitFor();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(process.getInputStream()));
String line = bufferedReader.readLine();
while (line != null) {
    System.out.println(line);
    line = bufferedReader.readLine();
}

当我从 Eclipse 运行 Java 程序时,我得到以下输出:

foo.rb:2:in `[]=': Invalid argument - ruby_setenv (Errno::EINVAL)
    from foo.rb:2:in `<main>'
Running test program

实际上,我正在从第三方产品(Vagrant)调用更大的 Ruby 脚本,为什么不能选择更改 Ruby 脚本。

为什么会这样?我可以通过以某种方式修改我的 Java 代码来解决它吗?

红宝石版本:ruby 1.9.3p0 (2011-10-30) [i386-mingw32]

更新:如果我从 cmd 窗口运行 java 代码,它实际上可以工作。当我从 Eclipse 中运行它时它不起作用。不幸的是,这并没有太大帮助,因为我正在开发一个我们将在 Eclipse 中运行的工具。

更新 2:如果我从 Eclipse 启动一个 cmd 窗口,当我在这个 cmd 窗口中运行 ruby​​ 脚本时,我会遇到同样的问题。这让我相信存在某种许可问题。但是,我看不到通过开始菜单启动的 cmd 和通过 Eclipse 启动的 cmd 之间的任何权限差异。两者都以相同的用户身份运行,并且我可以看到的进程的所有安全属性都是相同的。

更新 3:尝试了最新版本的 Ruby ( 2.0.0p247 (2013-06-27) [i386-mingw32])。相同的行为。

4

2 回答 2

1

问题是当我从 Eclipse 启动 Ruby 脚本时,我有一个不同的环境。具体来说,我有一个看起来很奇怪的 CLASSPATH 环境变量。我认为造成这种情况的原因是 CLASSPATH 变量的大小。在传递给我的子进程之前真的很长,但是在子进程中它被截断并且看起来被破坏了。

我怀疑我遇到了 Windows 环境块的最大大小的问题(请参阅此处的详细信息:http: //blogs.msdn.com/b/oldnewthing/archive/2010/02/03/9957320.aspx)。我不会对此进行进一步调查,但已修复我的代码以在开始该过程之前删除 CLASSPATH 变量。

Path path = FileSystems.getDefault().getPath("c:", "temp", "rb-test");
ProcessBuilder pb = new ProcessBuilder("ruby.exe","foo.rb").directory(path.toFile()).redirectErrorStream(true);
pb.environment().remove("CLASSPATH");
Process process = pb.start();
process.waitFor();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(process.getInputStream()));
String line = bufferedReader.readLine();
while (line != null) {
    System.out.println(line);
    line = bufferedReader.readLine();
}
于 2013-07-23T10:35:45.547 回答
1

作为此 Wocker 安装的一部分,在运行 vagrant 时遇到了类似的问题:

http://wckr.github.io/

问题是我的系统环境路径太长了。我从中剪掉了一大堆垃圾,流浪汉(基于红宝石)运行良好。

于 2016-07-28T13:56:26.263 回答