运行 maven exec 插件时 java 的错误版本

Posted

技术标签:

【中文标题】运行 maven exec 插件时 java 的错误版本【英文标题】:Bad version of java when running maven exec plugin 【发布时间】:2016-06-13 07:32:55 【问题描述】:

我当前的java版本是7:

java -version
java version "1.7.0_80"
Java(TM) SE Runtime Environment (build 1.7.0_80-b15)
Java HotSpot(TM) Server VM (build 24.80-b11, mixed mode)

我有命令 mvn8java_home 设置为 8:

mvn8 -version
Java HotSpot(TM) Server VM warning: ignoring option MaxPermSize=512m; support was removed in 8.0
Apache Maven 3.0.3 (r1075438; 2011-02-28 18:31:09+0100)
Maven home: /home/.../apache-maven-3.0.3
Java version: 1.8.0_66, vendor: Oracle Corporation
Java home: /home/.../jdk1.8.0_66/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux", version: "3.13.0-45-generic", arch: "i386", family: "unix"

现在问题来了。当我在项目中运行我的一个配置文件(有生成文件的 maven exec 插件)时:

mvn8 exec:exec -P mo2ja -o

我遇到了异常:

Java HotSpot(TM) Server VM warning: ignoring option MaxPermSize=512m; support was removed in 8.0
[INFO] Scanning for projects...
...
 ERROR:java.time.LocalDateTime cannot be resolved to a type. 
ERROR:java.time.LocalDate cannot be resolved to a type. 
[ERROR] Command execution failed.
org.apache.commons.exec.ExecuteException: Process exited with an error: 2 (Exit value: 2)
    at org.apache.commons.exec.DefaultExecutor.executeInternal(DefaultExecutor.java:404)
    at org.apache.commons.exec.DefaultExecutor.execute(DefaultExecutor.java:166)
    at org.codehaus.mojo.exec.ExecMojo.executeCommandLine(ExecMojo.java:764)
    at org.codehaus.mojo.exec.ExecMojo.executeCommandLine(ExecMojo.java:711)
    at org.codehaus.mojo.exec.ExecMojo.execute(ExecMojo.java:289)
    at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:101)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:209)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
    at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
    at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:84)
    at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:59)
    at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.java:183)
    at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:161)
    at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:319)
    at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:156)
    at org.apache.maven.cli.MavenCli.execute(MavenCli.java:537)
    at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:196)
    at org.apache.maven.cli.MavenCli.main(MavenCli.java:141)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:497)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:290)
    at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:230)
    at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409)
    at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:352)

所以它似乎仍然需要我的系统 java。为什么当 mvn 版本打印 java8 时?当我更改我的系统 java 时,它可以正常工作。这是 maven 的一些功能,也可能是我使用的插件问题?

更新:

当我调试 maven exec 插件时,我看到了这一行:

[DEBUG] Executing command line: java -classpath ... org.eclipse.jdt.internal.jarinjarloader.JarRsrcLoader -control definitions.model -models entity.model,dao.model -source src/main/resources -target src-gen

所以问题是如何使用与我执行 mvn 相同的 java 版本

这是我的个人资料:

    <profile>
        <id>mo2ja</id>
        <dependencies>
            <dependency>
                <groupId>org.sqlproc.model</groupId>
                <artifactId>sqlmodel</artifactId>
                <scope>runtime</scope>
            </dependency>
        </dependencies>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.codehaus.mojo</groupId>
                    <artifactId>exec-maven-plugin</artifactId>
                    <configuration>
                        <executable>java</executable>
                        <classpathScope>runtime</classpathScope>
                        <arguments>
                            <argument>-classpath</argument>
                            <classpath>
                                <dependency>org.sqlproc.model:sqlmodel</dependency>
                                <dependency>mysql:mysql-connector-java</dependency>
                                <dependency>org.sqlproc:sql-processor</dependency>
                                <dependency>org.slf4j:slf4j-api</dependency>
                            </classpath>
                            <argument>org.eclipse.jdt.internal.jarinjarloader.JarRsrcLoader</argument>
                            <argument>-control</argument>
                            <argument>definitions.model</argument>
                            <argument>-models</argument>
                            <argument>entity.model,dao.model</argument>
                            <argument>-source</argument>
                            <argument>src/main/resources</argument>
                            <argument>-target</argument>
                            <argument>src-gen</argument>
                        </arguments>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    </profile>

【问题讨论】:

编译插件的源和目标标签是否设置为1.8? 消息“ignoring option MaxPermSize=512m; support was removed in 8.0”表明使用了java 8。 插件中没有我没有源标签和目标标签 见下面我的回答。我认为这是你的问题。以前也遇到过。如果它解决了您的问题,请告诉我。 你能粘贴你的pom文件或者至少是特定的插件配置sn-p吗? 【参考方案1】:

更改您的 maven 编译器插件以允许级别 1.8

<plugins>
  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.5.1</version>
    <configuration>
      <source>1.8</source>
      <target>1.8</target>
    </configuration>
  </plugin>
</plugins>

【讨论】:

这对我不起作用。正如您在我的问题中看到的那样,我没有使用 maven 编译器插件,而是使用 exec:exec,它是 exec-maven-plugin。而且这里没有源元素和目标元素 好吧,也许我误解了,因为我认为 exec 插件超出了 maven 范围。即使您使用带有 java 8 的 maven,如果您没有指定编译级别,如果我没记错的话,它默认使用 1.5。这就是为什么我认为这是问题所在。奇怪的。希望其他人可以提供帮助。 这样的事情最好使用工具链。

以上是关于运行 maven exec 插件时 java 的错误版本的主要内容,如果未能解决你的问题,请参考以下文章

使用 Exec Maven 插件分叉 Java,而不使用 `exec` 目标

使用 Maven Exec 插件的多个命令

Maven exec插件未运行

Maven exec-maven-plugin和maven-resources-plugin没有运行,不知道为什么。

使用Maven运行Java main的3种方式

具有预览功能的 Maven Exec 插件