10

我已经在 Git Bash(64 位)上使用 Maven 几个月了,突然它停止了工作,现在在任何 maven 命令上都会产生这个错误:

myuser@mypc MINGW64 ~ (master *)
$ mvn -v
Error: Could not find or load main class org.codehaus.plexus.classworlds.launcher.Launcher

我已经查看了许多关于 SO 的问题,包括这个:Maven 错误:无法找到或加载主类 org.codehaus.plexus.classworlds.launcher.Launcher但还没有解决我的问题。

我已从 2.12 升级到最新的 Git for Windows (2.14.2.windows.2),但问题仍然存在。

我的 Maven 安装在 C:\apache-maven-3.5.0\bin,它在我的 PATH 变量中:

myuser@mypc MINGW64 ~ (master *)
$ echo $PATH
...:/c/jdk1.7.0_79/bin:/c/apache-maven-3.5.0/bin:...

我也正确设置了 JAVA_HOME:

myuser@mypc MINGW64 ~ (master *)
$ echo $JAVA_HOME
C:\jdk1.7.0_79

我尝试添加/删除 MAVEN_HOME,但在 Apache Maven 启动脚本 (C:\apache-maven-3.5.0\bin\mvn) 中似乎没有检测到:

myuser@mypc MINGW64 ~ (master *)
$ echo $MAVEN_HOME
c:\apache-maven-3.5.0

如果我进入 Apache Maven 启动脚本并将 ${MAVEN_HOME} 的实例替换为 C:\apache-maven-3.5.0,那么它似乎找到了 Launcher 类并正确执行。

像这样的编辑:

CLASSWORLDS_JAR=`echo "${MAVEN_HOME}"/boot/plexus-classworlds-*.jar`
  to
CLASSWORLDS_JAR=`echo /c/apache-maven-3.5.0/boot/plexus-classworlds-*.jar`

然后产生:

myuser@mypc MINGW64 ~ (master *)
$ mvn -v
Apache Maven 3.5.0 (ff8f5e7444045639af65f6095c62210b5713f426; 2017-04-03T15:39:06-04:00)
Maven home: C:\apache-maven-3.5.0
Java version: 1.7.0_79, vendor: Oracle Corporation
Java home: C:\jdk1.7.0_79\jre
Default locale: en_US, platform encoding: Cp1252
OS name: "windows 7", version: "6.1", arch: "amd64", family: "windows"

这是一个不优雅的解决方法,宁愿找到合适的解决方案。我可以尝试哪些环境或配置更改以允许 Maven 在不硬编码路径的情况下运行?


VonC 答案的步骤/结果:

Microsoft Windows [Version 6.1.7601]
Copyright (c) 2009 Microsoft Corporation.  All rights reserved.

C:\windows\system32>set PATH=C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\
C:\windows\system32>set GH=C:\Program Files\Git
C:\windows\system32>set PATH=%GH%\bin;%GH%\usr\bin;%GH%\mingw64\bin;%PATH%
C:\windows\system32>set PATH=%JAVA_HOME%\bin;%MAVEN_HOME%\bin;%PATH%

C:\windows\system32>echo %PATH%
C:\jdk1.7.0_79\bin;c:\apache-maven-3.5.0\bin;C:\Program Files\Git\bin;C:\Program Files\Git\usr\bin;C:\Program Files\Git\mingw64\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\

C:\windows\system32>echo %M2_HOME%
C:\apache-maven-3.5.0

C:\windows\system32>mvn -v
Apache Maven 3.5.0 (ff8f5e7444045639af65f6095c62210b5713f426; 2017-04-03T15:39:06-04:00)
Maven home: c:\apache-maven-3.5.0\bin\..
Java version: 1.7.0_79, vendor: Oracle Corporation
Java home: C:\jdk1.7.0_79\jre
Default locale: en_US, platform encoding: Cp1252
OS name: "windows 7", version: "6.1", arch: "amd64", family: "windows"

C:\Windows\System32>bash

myuser@mypc MINGW64 /c/Windows/System32
$ mvn -v
Error: Could not find or load main class org.codehaus.plexus.classworlds.launcher.Launcher

myuser@mypc MINGW64 /c/Windows/System32
$ echo $M2_HOME
C:\apache-maven-3.5.0

S279887@P2025774 MINGW64 /c/Windows/System32
$ echo $MAVEN_HOME
c:\apache-maven-3.5.0

经过进一步调试,我意识到我的问题似乎与MINGW Git bash 中的 Maven 错误相同:无法找到或加载主类 org.codehaus.plexus.classworlds.launcher.Launcher,其中 MAVEN_HOME 变量在这部分代码中被清除:

# For MinGW, ensure paths are in Unix format before anything is touched
if $mingw ; then
  [ -n "$MAVEN_HOME" ] &&
    MAVEN_HOME=`(cd "$MAVEN_HOME"; pwd)`
  [ -n "$JAVA_HOME" ] &&
    JAVA_HOME=`(cd "$JAVA_HOME"; pwd)`
  # TODO classpath?
fi

如果我[[ -n "$MAVEN_HOME" ]] && MAVEN_HOME=`(cd "$MAVEN_HOME"; pwd)`在 bash 会话中运行有问题的行,我可以在最新的 Git for Windows 中重现该行为:

myuser@mypc MINGW64 ~ (master *)
$ git --version
git version 2.14.2.windows.3

myuser@mypc MINGW64 ~ (master *)
$ echo $MAVEN_HOME
c:\apache-maven-3.5.0

myuser@mypc MINGW64 ~ (master *)
$ [[ -n "$MAVEN_HOME" ]] && MAVEN_HOME=`(cd "$MAVEN_HOME"; pwd)`

myuser@mypc MINGW64 ~ (master *)
$ echo $MAVEN_HOME


myuser@mypc MINGW64 ~ (master *) 
$

这就是我直接执行命令时得到的结果——它返回当前目录,而不是我期望的 MAVEN_HOME。假设发生这种情况是因为命令在子 shell 中执行?

myuser@mypc MINGW64 ~ (master *)
$ echo `(cd "$MAVEN_HOME"; pwd)`
/c/home

myuser@mypc MINGW64 ~ (master *)
$ `(cd "$MAVEN_HOME"; pwd)`
bash: /c/home: Is a directory
4

1 回答 1

1

首先要测试的是%PATH%:在 CMD 会话中,设置一个简化 PATH的.

set PATH=C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\
set GH=C:\path\to\git
set PATH=%GH%\bin;%GH%\usr\bin;%GH%\mingw64\bin;%PATH%

请注意C:\WINDOWS\...路径如何保存在PATH的末尾:这很重要。

然后在前面加上你的路径%JAVA_HOME%\bin<maven>\bin

并确保设置M2_HOMEC:\apache-maven-3.5.0.

最后,mvn在当前 CMD 或(在同一个 Windows 中)在 git bash 会话中测试您的命令(只需键入“ bash”)

最后,根据您的程序和您的操作系统品牌,不要忘记使用 Windows 10 您现在拥有WSL 和成熟的 Linux bash。这可能是一种可能的选择。

于 2017-10-16T19:47:27.650 回答