簡體   English   中英

我不能在沒有 slf4j 的情況下使用 log4j 嗎?

[英]Can't I use log4j without slf4j?

我正在嘗試將log4j用於作為 JAR 運行的簡單的小型 maven 應用程序。 我知道slf4j有很多好處,但我試圖讓這盡可能簡單,而不是求助於System.out

我的pom.xml有以下內容:

<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>

它主要工作,它按照我的log4j.properties指示記錄到文件。 但 ...

...我在控制台中得到以下信息:

SLF4J: slf4j-api 1.6.x (or later) is incompatible with this binding.
SLF4J: Your binding is version 1.5.5 or earlier.
SLF4J: Upgrade your binding to version 1.6.x.
Exception in thread "main" java.lang.NoSuchMethodError: org.slf4j.impl.StaticLoggerBinder.getSingleton()Lorg/slf4j/impl/StaticLoggerBinder;
        at org.slf4j.LoggerFactory.bind(LoggerFactory.java:129)
        at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:108)
        at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:302)
        at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:276)
        at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:155)
        at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:131)
        at org.apache.commons.logging.LogFactory.getLog(LogFactory.java:351)

似乎這可能來自以下依賴項:

   <dependency>
        <groupId>commons-httpclient</groupId>
        <artifactId>commons-httpclient</artifactId>
        <version>3.1</version>
    </dependency>

由於日志記錄直接有效,並且在遇到commons-httpclient內容時會拋出錯誤。

我已經嘗試將各種slf4j依賴項添加到我的pom.xml但沒有任何幫助,也無助於我理解實際問題。

有沒有辦法只使用log4j而沒有任何錯誤? 如果不是,如何消除這個錯誤?

首先嘗試檢查您的其他項目依賴項中哪些依賴於slf4j

mvn dependency:tree

[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building MavenScrap 1.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] --- maven-dependency-plugin:2.1:tree (default-cli) @ MavenScrap  ---
[INFO] sub.optimal:MavenScrap:jar:1.0-SNAPSHOT
[INFO] +- commons-httpclient:commons-httpclient:jar:3.1:compile
[INFO] |  +- commons-logging:commons-logging:jar:1.0.4:compile
[INFO] |  \- commons-codec:commons-codec:jar:1.2:compile
[INFO] \- log4j:log4j:jar:1.2.17:compile
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------

檢查你的依賴樹

 mvn dependency:tree

找出哪個依賴項具有可傳遞的 slf4j 依賴項。 我懷疑它是 commons-httpclient,因為它只有以下依賴項(並使用 commons 日志記錄):

[INFO] --- maven-dependency-plugin:2.10:tree (default-cli) @ log4j ---
[INFO] binding:log4j:jar:0.0.1-SNAPSHOT
[INFO] \- commons-httpclient:commons-httpclient:jar:3.1:compile
[INFO]    +- commons-logging:commons-logging:jar:1.0.4:compile
[INFO]    \- commons-codec:commons-codec:jar:1.2:compile

您最終必須找出使用的是哪個 slf4j-api 版本(檢查mvn dependency:resolve )並提供匹配的 log4j 綁定庫(參見SLF4J 手冊)。

    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>x.x.x</version>
    </dependency>

我們需要了解一些差異。

對於圖書館制作者

在這種情況下,我們正在開發一個 java 庫,未來的目標是包含在一個項目中。 因此,如果我們想上天堂,我們不應該在庫中使用專有的日志記錄提供程序(logback、log4j、jdk 日志記錄)。 我們可以認為將使用我們庫的項目可以免費使用任何記錄器提供程序。

對於這個場景,SLF4J 幫助我們。

pom.xml

<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-api</artifactId>
  <version>1.7.5</version>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-simple</artifactId>
  <version>1.7.5</version>
</dependency>

示例.java

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
private final Logger logger = LoggerFactory.getLogger(getClass());
Logger.info("hello");

現在,您可以在具有 INFO 級別的 STDOUT 上看到日志記錄輸出。 這個簡單的記錄器將默認顯示任何 INFO 級別或更高級別的消息。 為了查看 DEBUG 消息,您需要在 Java 啟動時將級別設置為系統屬性(選擇一項)

  • -Dorg.slf4j.simpleLogger.defaultLogLevel=DEBUG
  • System.setProperty("org.slf4j.simpleLogger.defaultLogLevel", "DEBUG");

對於應用程序制造商

在這種情況下,我們不是在開發庫。 所以我們可以自由使用我們喜歡的任何記錄器提供者。 就我而言,我喜歡 log4j2。

pom.xml

<dependency>
  <groupId>org.apache.logging.log4j</groupId>
  <artifactId>log4j-api</artifactId>
  <version>2.7</version>
</dependency>
<dependency>
  <groupId>org.apache.logging.log4j</groupId>
  <artifactId>log4j-core</artifactId>
  <version>2.7</version>
</dependency>
<dependency>
  <groupId>org.apache.logging.log4j</groupId>
  <artifactId>log4j-slf4j-impl</artifactId>
  <version>2.7</version>
</dependency>

src/main/resources/log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
  <Appenders>
    <Console name="Console" target="SYSTEM_OUT">
      <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
    </Console>
  </Appenders>
  <Loggers>
    <Root level="debug">
      <AppenderRef ref="Console"/>
    </Root>
  </Loggers>
</Configuration>

示例.java

import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.LogManager;
private final Logger logger = LogManager.getLogger(this.getClass());
Logger.info("hello");

使用這些最小配置,您將使用 log4j 配置獲得快樂和健康的日志。

如果您導入的庫使用 SLF4J,您將在 log4j 的同一頻道中看到它的日志。

但是如果你導入的庫沒有使用 SLF4J,例如:logback 或 jdk-logging,你就不能在你的log4j的同一個頻道看到他們的日志,可能會是一場噩夢


參考

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM