在 cygwin 下的 Windows 7 中安装 mahout



我已经成功地在Windows 7 pro 64位的cygwin下安装了hadoop。

现在我正在努力安装驯象师,但我不能。

设置MAHOUT_HOME和变量并在cygwin上运行驯象师后,出现以下错误

我想这与 cygwin 和 Windows 路径之间的兼容性问题有关,但我找不到我应该更改哪个特定路径。

Running on hadoop, using /cygdrive/c/hadoop/bin/hadoop and HADOOP_CONF_DIR=
MAHOUT-JOB: /cygdrive/c/mahout/mahout-examples-0.7-job.jar
Exception in thread "main" java.io.IOException: Error opening job jar: /cygdrive               /c/mahout/mahout-examples-0.7-job.jar
    at org.apache.hadoop.util.RunJar.main(RunJar.java:90)
Caused by: java.io.FileNotFoundException: cygdrivecmahoutmahout
examples-0.7               
-job.jar (The system cannot find the path specified)
    at java.util.zip.ZipFile.open(Native Method)
    at java.util.zip.ZipFile.<init>(ZipFile.java:214)
    at java.util.zip.ZipFile.<init>(ZipFile.java:144)
    at java.util.jar.JarFile.<init>(JarFile.java:152)
    at java.util.jar.JarFile.<init>(JarFile.java:89)
    at org.apache.hadoop.util.RunJar.main(RunJar.java:88)

可能/cygdrive/c/mahout/mahout-examples-0.7-job.jar 应该是 C:\mahout\mahout-examples-0.7-job.jar。

     MAHOUT_JOB=`cygpath -wp $MAHOUT_JOB

Java是一个Windows程序,因此不识别Cygwin特定的路径。所以/cygdrive/c/foo/...对Java.exe没用。如果您的 Java 软件使用文件路径,则需要使用 Cygwin 附带的 cygpath 工具将它们转换为 Windows 样式的路径名。

cygpath将UNIX风格的路径作为参数,并返回Windows风格的路径。下面是一个示例:

    $ cygpath -wp /cygdrive/c:/cygdrive/c/classes
    c:;c:classes

因此,当调用Java程序(例如,从shell脚本中)时,您需要像这样编写命令行:

java -classpath `cygpath -wp $CLASSPATH` [arguments]

参考: http://www.inonit.com/cygwin/faq/

相关内容

  • 没有找到相关文章

最新更新