【问题标题】:How do I use log4j with Maven and executable jar file?如何将 log4j 与 Maven 和可执行 jar 文件一起使用?
【发布时间】:2013-05-19 23:14:00
【问题描述】:

我正在尝试让 log4j 在一个简单的应用程序中工作,但我收到了以下消息:

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/log4j/Logger

我使用以下命令执行应用程序:

java -jar lunchtracker-1.0-SNAPSHOT.jar

log4j.properties 文件位于 src/main/resources 中。这是我的 pom.xml:

<project <snip -- was messing up formatting>>
    <modelVersion>4.0.0</modelVersion>
    <groupId>net.uofitorn</groupId>
    <artifactId>lunchtracker</artifactId>
    <packaging>jar</packaging>
    <version>1.0-SNAPSHOT</version>
    <name>lunchtracker</name>
    <url>http://maven.apache.org</url>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <configuration>
                    <archive>
                        <manifest>
                            <addClasspath>true</addClasspath>
                            <classpathPrefix>lib/</classpathPrefix>
                            <mainClass>net.uofitorn.LunchTrackerServer</mainClass>
                        </manifest>
                    </archive>
                </configuration>
            </plugin>
        </plugins>
    </build>

    <dependencies>
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.16</version>
            <scope>compile</scope>
        </dependency>
    </dependencies>
</project>

这是我的java代码:

import org.apache.log4j.Logger;
<snip>
Logger logger = Logger.getLogger(LunchTrackerServer.class.getName());
logger.debug("Server started");

我认为问题是 log4j jar 未包含在我的 jar 文件中。当我解压缩罐子时,我看不到它。如何让 maven 在我的 jar 中包含 log4j 依赖项?

【问题讨论】:

  • 对此我不是 100%,但我相信您可以在 java 命令中包含所有必要的 jar,如下所示:java -cp "lunchtracker-1.0-SNAPSHOT.jar;path-to-log4j-jar/log4j-1.2.16.jar" my.package.MainClass

标签: java maven log4j


【解决方案1】:

您需要在运行时提供log4j 依赖项,并提供您需要在您的jar 中打包log4j 工件Here is how you can create fat jar

【讨论】:

    【解决方案2】:

    您需要做的是创建一个捆绑了依赖项的可执行 JAR。

    有几种方法。

    使用Maven Assembly Plugin

    Maven Shade plugin也是另一个不错的选择

    【讨论】:

      【解决方案3】:

      当使用 maven 进行依赖管理时,您应该使用 IDE 将依赖添加到类路径中,或者使用 maven exec:java 目标 maven exec 插件运行主类(请参阅 http://mojo.codehaus.org/exec-maven-plugin/java-mojo.html)。

      为此,您需要在 pom.xml 中指定您的主类并使用以下命令从命令行运行它:

      mvn exec:java
      

      或者直接从命令行运行:

      mvn exec:java -Dexec.mainClass="net.uofitorn.LunchTrackerServer"
      

      【讨论】:

        猜你喜欢
        • 2016-11-08
        • 2018-04-23
        • 2015-08-20
        • 2016-10-13
        • 2017-03-19
        • 2011-08-03
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多