【问题标题】:log4j in simple java maven project简单的java maven项目中的log4j
【发布时间】:2013-11-24 00:18:48
【问题描述】:

我有一个简单的 java 项目。我使用 maven 管理我的依赖项。我在 pom.xml 中添加了 log4j 依赖项

现在我想利用

package com.abc.xyz;

import org.apache.log4j.Logger;

/**
 * Hello world!
 *
 */
public class App 
{
    static final Logger logger = Logger.getLogger(App.class);
    public static void main( String[] args )
    {
        logger.debug("Hello world!");
    }
}

资源文件夹中有我的 log4j.properties 文件。

当我将 App 作为 Java 应用程序运行时,出现以下错误。

log4j:WARN No appenders could be found for logger (com.abc.xyz.App).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

所以,我的问题是如何让运行时知道我的 log4j.properties 文件在资源文件夹中。

编辑

这是我的 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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.abc.xyz</groupId>
  <artifactId>learning</artifactId>
  <packaging>jar</packaging>
  <version>1.0-SNAPSHOT</version>
  <name>learning</name>
  <url>http://maven.apache.org</url>
  <dependencies>
  <dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
  </dependencies>
  <build>
  <plugins>
    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>2.3.2</version>
        <configuration>
            <source>1.6</source>
            <target>1.6</target>
        </configuration>
    </plugin>
 </plugins>
 </build>
</project>

这是我的 log4j.properties 文件

# Define the root logger with appender file
log4j.rootLogger = DEBUG

【问题讨论】:

  • 我们可以看看你的 pom.xml 吗

标签: java eclipse maven log4j


【解决方案1】:

将 log4j 的 pom.xml 依赖项更改为:

<dependencies>
  <dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.0-beta9</version>
  </dependency>
  <dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.0-beta9</version>
  </dependency>
</dependencies>

看看有没有效果

【讨论】:

    【解决方案2】:

    将系统属性log4j.configuration 设置为文件的运行时路径。这可以在应用程序启动器中完成。像这样,假设您的配置文件位于工作目录的根目录中(因为您说您的文件位于 src/main/resources maven 会将其移动到根目录)

    -Dlog4j.configuration=log4j.properties
    

    但我不得不说,如果你的文件真的被称为 log4j.properties 并且它确实在 src/main/resources 你不应该需要这个,因为 log4j 默认会在那里寻找它

    【讨论】:

    • 我正在使用 Eclipse。我正在将 App.java 作为 java 应用程序运行。
    • 在应用程序的Run COnfigurations 中,转到“参数”选项卡并在“VM 参数”部分输入我告诉你的配置,但指向文件的实际位置
    • 我试过了。完全相同的事情。即使使用绝对文件路径。我收到同样的错误信息。
    • 然后添加这个属性 -Dlog4j.debug 这将打印一些 log4j 信息,告诉你他期望文件在哪里,以及其他有用的东西
    【解决方案3】:

    我修改了我的 App 类如下:

    public class App 
    {
        static final Logger logger = Logger.getLogger(App.class);
        public static void main( String[] args )
        {
            PropertyConfigurator.configure("/absolute/path/to/log4j.properties");
            logger.debug("Hello world!");
        }
    }
    

    【讨论】:

      【解决方案4】:

      您应该将 log4j.properties 放在项目的 src/main/resources 文件夹下以避免警告或使用 -Dlog4j.configuration=&lt;FILE_PATH&gt; 提供文件路径

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2019-01-29
        • 1970-01-01
        • 1970-01-01
        • 2016-03-30
        • 1970-01-01
        • 2018-08-30
        • 1970-01-01
        相关资源
        最近更新 更多