【问题标题】:Could not find or load main class $JAVA_OPTS无法找到或加载主类 $JAVA_OPTS
【发布时间】:2017-07-28 08:46:11
【问题描述】:

我正在尝试为 Heroku 平台配置 Procfile 文件以在本地运行应用程序。我正在尝试运行基于 Tomcat 的 Java Web 应用程序。

在教程中他们说:

To build your app locally do this:
Use the Git Bash application to open a command shell on Windows.
$ mvn clean install
$ heroku local web

我在项目目录中,在mvn clean install之后我收到了

BUILD SUCCESS

问题是当我运行时:heroku local web 我收到[WARN] No ENV file found web.1 | Error: Could not find or load main class $JAVA_OPTS

我的 Procfile 有 1 行:

web: java $JAVA_OPTS -jar 目标/依赖/webapp-runner.jar --port $PORT 目标/*.war

我正在使用 Windows。我在堆栈上看到了post,他们说 Procfile 中 Windows 上的代码不同。它应该看起来像这样(我的创作):

web: java %JAVA_OPTS% -jar target\dependency\webapp-runner.jar --port %PORT% 目标*.war

我必须在目标文件夹中创建一个名为“dependency”的文件夹吗?因为我的项目中没有 webbapp-runner.jar,我不明白该怎么办。

这是我的 pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.rares</groupId>
<artifactId>first-web-application</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>

<dependencies>
    <dependency>
        <groupId>com.github.jsimone</groupId>
        <artifactId>webapp-runner</artifactId>
        <version>8.5.11.2</version>
    </dependency>
    <dependency>
        <groupId>javax</groupId>
        <artifactId>javaee-web-api</artifactId>
        <version>6.0</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>4.3.6.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>
</dependencies>

<build>
    <pluginManagement>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.2</version>
                <configuration>
                    <verbose>true</verbose>
                    <source>1.8</source>
                    <target>1.8</target>
                    <showWarnings>true</showWarnings>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <version>2.2</version>
                <configuration>
                    <path>/</path>
                    <contextReloadable>true</contextReloadable>
                </configuration>
            </plugin>
        </plugins>
    </pluginManagement>
</build>

我应该将 webapp-runner 添加为插件吗?

【问题讨论】:

  • 您是否尝试过您分享的同一篇文章中的其他解决方案?喜欢web: java %JAVA_OPTS% -cp target\classes;"target\dependency\*" Main。你可以关注this
  • 我的主要课程是什么?我只有一个 LoginController java 类和 Login Service ..一个带有方法的控制器类
  • @ProhIsMetal 服务类应该是一个。理想情况下是您希望从中启动应用程序的类。
  • 稍后我会在尝试将日志上传到 heroku 时发布错误日志。但是由于这个错误,我基本上无法为应用程序创建本地服务器......我想在本地测试它,因为当我在 eclipse 中使用 tomcat 运行应用程序时,我可以在 localhost:8080/login 看到我想要的。我想提一下,我的 LoginService 类只有 1 个返回 true 或 false 的方法 isTrue。你确定这样能解决问题吗?
  • 如果您能对这个问题投票,那就太好了!也许有人知道更好的解决方案。谢谢!

标签: java maven tomcat heroku


【解决方案1】:

您需要像这样将 webapp-runner 添加到您的pom.xml

      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-dependency-plugin</artifactId>
        <version>2.3</version>
        <executions>
            <execution>
                <phase>package</phase>
                <goals><goal>copy</goal></goals>
                <configuration>
                    <artifactItems>
                        <artifactItem>
                            <groupId>com.github.jsimone</groupId>
                            <artifactId>webapp-runner</artifactId>
                            <version>8.5.11.2</version>
                            <destFileName>webapp-runner.jar</destFileName>
                        </artifactItem>
                    </artifactItems>
                </configuration>
            </execution>
        </executions>
    </plugin>

那么您的Procfile 可以如下所示:

web: java $JAVA_OPTS -jar target/dependency/webapp-runner.jar --port $PORT target/*.war

而您的Procfile.windows 可能看起来像这样:

web: java %JAVA_OPTS% -jar target\dependency\webapp-runner.jar --port %PORT% target\*.war

欲了解更多信息,请参阅Deploying Tomcat-based Java Web Applications with Webapp Runner

【讨论】:

  • 请使用uptodate versions of plugins 而不是那么古老的版本...
  • 我必须在某个地方定义 $JAVA_OPTS?
  • 当我运行时:mvn package 我收到构建成功并且在 java -jar target/dependency/webapp-runner.jar target/*.war 我收到:错误无法访问 jarfile target/dependency/webapp -runner.jar
【解决方案2】:

所以我在 stackoverflow 上阅读了很多关于此错误的帖子 + Heroku 上的教程,但没有找到解决方案,但我做出了改进。我阅读了this post 并删除了pom.xml 中的开始&lt;pluginManagement&gt; 和结束&lt;pluginManagement/&gt; 标记,现在创建了dependency 目录和webapp-runner-8.0.30.1.jar。 我的应用程序正在运行,因为如果我在 Eclipse 中使用 Tomcat 运行我的应用程序,我可以转到 localhost:8080/login 并且可以看到我的网站。 当我跑步时:

mvn 包

我收到build succes,然后我在 cmd 中运行

java -jar 目标/依赖/webapp-runner.jar 目标/*.war

我收到:error invalid or corrupt jarfile target/dependency/webapp-runner.jar

这是我的 Procfile:

web: java $JAVA_OPTS -jar target/dependency/webapp-runner.jar --port $PORT 目标/*.war

这是我的 Procfile.windows:

web: java %JAVA_OPTS% -jar target\dependency\webapp-runner.jar --port %PORT% target*.war

我的 pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.rares</groupId>
<artifactId>first-web-application</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>

<dependencies>
    <dependency>
        <groupId>javax</groupId>
        <artifactId>javaee-web-api</artifactId>
        <version>6.0</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>4.3.6.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>
</dependencies>

<build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.2</version>
                <configuration>
                    <verbose>true</verbose>
                    <source>1.8</source>
                    <target>1.8</target>
                    <showWarnings>true</showWarnings>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <version>2.2</version>
                <configuration>
                    <path>/</path>
                    <contextReloadable>true</contextReloadable>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-dependency-plugin</artifactId>
                <version>2.3</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>copy</goal>
                        </goals>
                        <configuration>
                            <artifactItems>
                                <artifactItem>
                                    <groupId>com.github.jsimone</groupId>
                                    <artifactId>webapp-runner</artifactId>
                                    <version>8.5.11.2</version>
                                    <destFileName>webapp-runner.jar</destFileName>
                                </artifactItem>
                            </artifactItems>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
</build>

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2019-01-05
    • 2015-02-06
    • 2018-10-10
    • 2014-09-15
    • 2015-09-10
    • 2015-08-22
    相关资源
    最近更新 更多