日志记录

从 Spring 框架 5.0 开始,Spring 自带了在 spring-jcl 模块中实现的 Commons Logging 桥接。该实现检查类路径中是否存在 Log4j 2.x API 和 SLF4J 1.7 API,并使用找到的第一个作为日志记录实现,如果 Log4j 2.x 和 SLF4J 都不可用,则回退到 Java 平台的核心日志记录设施(也称为 *JUL* 或 java.util.logging)。

将 Log4j 2.x 或 Logback(或其他 SLF4J 提供者)放在您的类路径中,无需任何额外的桥接,让框架自动适应您的选择。有关更多信息,请参阅 Spring Boot 日志记录参考文档

Spring 的 Commons Logging 变体仅用于核心框架和扩展中的基础设施日志记录目的。

对于应用程序代码中的日志记录需求,请优先使用 Log4j 2.x、SLF4J 或 JUL。

可以通过 org.apache.commons.logging.LogFactory 获取 Log 实现,如下例所示。

  • Java

  • Kotlin

public class MyBean {
	private final Log log = LogFactory.getLog(getClass());
    // ...
}
class MyBean {
  private val log = LogFactory.getLog(javaClass)
  // ...
}