我有一个非常简单的 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 版本: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]
)。同样的行为。
最佳答案
问题是,当我从 Eclipse 启动 Ruby 脚本时,我有一个不同的环境。具体来说,我有一个看起来非常奇怪的 CLASSPATH 环境变量。我认为造成这种情况的原因是 CLASSPATH 变量的大小。在传递到我的子流程之前确实很长,但在子流程中它被截断并且看起来已损坏。
我怀疑我遇到了 Windows 环境 block 最大大小的问题(请参阅此处的详细信息: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();
}
关于java - 从 Windows 上的 Java 进程启动时,设置环境变量的 Ruby 脚本失败,并出现参数无效 - ruby_setenv (Errno::EINVAL),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17789522/