如何将log4j与Maven和可执行jar文件一起使用?

时间:2013-05-19 23:14:00

标签: java maven log4j

我正在尝试让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");

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

3 个答案:

答案 0 :(得分:4)

您需要在运行时提供log4j依赖关系,并提供您需要使用jar包装log4j工件,Here is how you can create fat jar

答案 1 :(得分:0)

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

有几种方法可以做。

使用Maven Assembly Plugin

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

答案 2 :(得分:0)

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

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

mvn exec:java

或者直接从命令行运行它:

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