如何使java.util.logging将日志发送到Logback?

22

我正在开发一个使用 slf4j API 记录日志的应用程序:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

...

private static final Logger LOG = LoggerFactory.getLogger(FreemarkerEmailPreviewGenerator.class);

...

LOG.error("Error generating email preview", e);

(上面的代码用于显示正在使用的类和包,但这是相当标准的内容。)

我们使用如下配置的logback:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>[%d{HH:mm:ss.SSS}] [%thread] [%-5level %logger{26} - %msg]%n
            </pattern>
        </encoder>
    </appender>

    <root>
        <level value="debug" />
        <appender-ref ref="STDOUT" />
    </root>

</configuration>

我们的一些代码使用第三方库,这些库使用java.util.logging进行日志记录,特别是freemarker。从以下控制台日志条目中可以看出,logback和j.u.l都会将日志记录到控制台,但它们没有使用相同的配置(logback条目使用我们的模式,而j.u.l则没有)

[12:24:38.842] [pool-2-thread-19] [INFO  u.o.n.r.l.s.e.t.TemplateLoaderFromService - Finding template workflow/mail/templates/common/workflow-macros.ftl]
[12:24:38.859] [pool-2-thread-19] [INFO  u.o.n.r.l.s.e.t.TemplateLoaderFromService - Loaded template workflow/mail/templates/common/workflow-macros.ftl as /workflow/mail/templates/common/workflow-macros.ftl from RegistryMailTemplateService.]
11-Jan-2017 12:24:38 freemarker.log.JDK14LoggerFactory$JDK14Logger error
SEVERE:

Expression domainContact is undefined on line 9, column 74 in workflow/mail/templates/common/workflow-macros.ftl.
The problematic instruction:
----------
==> ${domainContact.name} [on line 9, column 72 in workflow/mail/templates/common/workflow-macros.ftl]

是否可以使 j.u.l 日志记录使用 logback 配置,以便我们在整个应用程序中拥有单一一致的日志记录配置?


1个回答

15

您的应用程序需要以下jar包:

Application -> Freemarker -> java.util.logging -> SLF4J Api:jul-to-slf4j.jar

Application -> SLF4J API:slf4j-api.jar

SLF4J API -> logback:logback-classic.jar和logback-core.jar

由于您的应用程序已经包含 slf4j-api.jar 和 logback-classic.jar,您可能只需要添加 jul-to-slf4j.jar

如果您使用 Maven:

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>jul-to-slf4j</artifactId>
    <version>1.7.22</version>
</dependency>

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.1.8</version>
</dependency>

logback经典版本会自动添加logback-core和slf4j-api依赖。


9
是的,你的回答结合重复问题的链接帮助我实现了这个功能。我需要jul-to-slf4j,并使用SLF4JBridgeHandler.removeHandlersForRootLogger();和SLF4JBridgeHandler.install();来启用桥接。 - Nathan Russell

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接