相同的项目在两台不同的笔记本电脑上使用maven构建。在一个运行好的和一个显示错误。
状态:两个系统的配置相同。
C:\Users\admin>mvn -version
Apache Maven 2.2.1 (r801777; 2009-08-07 00:46:01+0530)
Java version: 1.6.0_43
Java home: C:\Installers\Java\jdk1.6.0_43\jre
Default locale: en_IN, platform encoding: Cp1252
OS name: "windows 7" version: "6.1" arch: "amd64" Family: "windows"
使用的命令: mvn clean install -DskipTests = true
错误:
[INFO] [compiler:compile {execution: default-compile}]
[INFO] Compiling 3 source files to C:\Users\admin\HeliosWorkspace\...\target\classes
[INFO] ------------------------------------------------------------------------
[ERROR] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Compilation failure
Failure executing javac, but could not parse the error:
The system cannot find the path specified.
[INFO] ------------------------------------------------------------------------
[INFO] Trace
org.apache.maven.BuildFailureException: Compilation failure
Failure executing javac, but could not parse the error:
The system cannot find the path specified.
at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoals(DefaultLifecycleExecutor
.java:715)
at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoalWithLifecycle(DefaultLifec
ycleExecutor.java:556)
at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoal(DefaultLifecycleExecutor.
java:535)
at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoalAndHandleFailures(DefaultL
ifecycleExecutor.java:387)
at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeTaskSegments(DefaultLifecycleE
xecutor.java:348)
at org.apache.maven.lifecycle.DefaultLifecycleExecutor.execute(DefaultLifecycleExecutor.java
:180)
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:328)
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:138)
at org.apache.maven.cli.MavenCli.main(MavenCli.java:362)
at org.apache.maven.cli.compat.CompatibleMain.main(CompatibleMain.java:60)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.codehaus.classworlds.Launcher.launchEnhanced(Launcher.java:315)
at org.codehaus.classworlds.Launcher.launch(Launcher.java:255)
at org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:430)
at org.codehaus.classworlds.Launcher.main(Launcher.java:375)
Caused by: org.apache.maven.plugin.CompilationFailureException: Compilation failure
Failure executing javac, but could not parse the error:
The system cannot find the path specified.
我甚至尝试删除所有内容,例如再次创建.m2文件夹。
答案 0 :(得分:5)
我遇到了这个问题,并通过一些故障排除解决了这个问题。
当您尝试执行文件但输入无效路径时,这实际上是一条DOS错误消息。
C:\Users\me>c:\asdf\foo.exe
The system cannot find the path specified.
Maven正在尝试执行javac来编译代码但没有正确的路径。对于许多设置,您需要在pom.xml中检查编译器的路径。转到cmd提示符并将其复制并粘贴,并确保其有效路径。
对于使用settings.xml配置文件在不同JAVA_HOME上定义某些全局配置的设置,例如下面的示例,确保每个变量中的路径都正确,带有这些变量的配置文件是活动的(activeProfile标记可以确保这一点),并在pom.xml中正确引用
<!-- settings.xml -->
<profiles>
<profile>
<id>compiler-versions</id>
<properties>
<JAVA_1_5_HOME>C:/java/jdk1.5.0_16</JAVA_1_5_HOME>
<JAVA_1_6_HOME>C:/java/jdk1.6.0_43</JAVA_1_6_HOME>
<JAVA_1_7_HOME>C:/java/jdk1.7.0_55</JAVA_1_7_HOME>
</properties>
</profile>
</profiles>
<activeProfiles>
<!-- make the profile active all the time -->
<activeProfile>compiler-versions</activeProfile>
</activeProfiles>
pom.xml片段:
<!-- pom.xml -->
<!-- ... -->
<build>
<configuration>
<verbose>false</verbose>
<fork>true</fork>
<executable>${JAVA_1_6_HOME}/bin/javac</executable>
<compilerVersion>1.6</compilerVersion>
<meminitial>256m</meminitial>
<source>1.6</source>
<target>1.6</target>
<!--encoding>UTF-8</encoding-->
<maxmem>512m</maxmem>
</configuration>
</build>
答案 1 :(得分:2)
谢谢大家,现在正在努力:
mvn -X clean install -DskipTests=true
调试模式非常有用。
答案 2 :(得分:0)
检查您的POM文件并确保您拥有适用于MAVEN和Java的正确环境变量
答案 3 :(得分:0)
我有一个类似的问题,我发现settings.xml @ Maven_home / conf或C:\ Users \ .m2 \ settings.xml指向错误的JDK路径,纠正哪个确实解决了问题。上面打印的错误消息实际上是“执行javac失败”的位置,这意味着Maven没有找到JDK。
由于 Hithesh
答案 4 :(得分:0)
我知道这是一个古老的话题,但我认为这个答案将有助于未来的人们:
Java home:C:\ Installers \ Java \ jdk1.6.0_43 \ jre
您正在使用JRE而不是JDK。只需从您的java主页中删除“\ jre”