log4j2 java.lang.NoClassDefFoundError:org / apache / logging / log4j / LogManager

时间:2015-09-03 06:48:38

标签: java eclipse maven log4j2

我在我的java应用程序中使用log4j 2.3。我通过maven添加了依赖 在eclipse中运行程序时一切正常,但是当我用maven打包它并尝试运行jar时我得到以下错误:

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache logging/log4j/LogManager
    at main.myclass.<clinit>(myclass.java:11)
Caused by: java.lang.ClassNotFoundException: org.apache.logging.log4j.LogManager 


    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 1 more

为什么从jar中运行它时无法找到类?

添加log4j 1.2也不起作用。该程序在eclipse中正常运行,因此不应该缺少依赖。

2 个答案:

答案 0 :(得分:11)

当您从命令行运行应用程序jar时,您的依赖jar在运行时不可用。您需要将这两个插件中的任何一个包含到pom.xml中,以便在运行时使用您的依赖项。

使用:maven-shade-plugin

<plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-shade-plugin</artifactId>
        <version>2.4.1</version>
        <executions>
          <execution>
            <phase>package</phase>
            <goals>
              <goal>shade</goal>
            </goals>
            <configuration>
              <transformers>
                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                  <mainClass>org.sonatype.haven.HavenCli</mainClass>
                </transformer>
              </transformers>
            </configuration>
          </execution>
        </executions>
      </plugin>

使用:行家依赖性-插件

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-dependency-plugin</artifactId>
    <version>2.8</version>
    <executions>
        <execution>
             <id>copy-dependencies</id>
             <phase>package</phase>
             <goals>
                 <goal>copy-dependencies</goal>
             </goals>
             <configuration>
                 <outputDirectory>${project.build.directory}/lib</outputDirectory>
             </configuration>
        </execution>
     </executions>
</plugin>

当您执行mvn package时,它将生成uber jar /或将依赖项复制到outputDirectory。我更喜欢maven-shade-plugin生成一个jar将所有依赖项。

答案 1 :(得分:0)

安装最新版本的log4j (我已经安装了log4j-2.3.jar

并执行以下步骤:

  • 右键单击项目->构建路径->库->添加外部Jars->包括Log4j,Log4j core和Log4j api jars。

对我有用