gpt4 book ai didi

tomcat - 通过 logback/sl4j 进行嵌入式 Tomcat 日志记录

转载 作者:行者123 更新时间:2023-11-28 21:48:24 24 4
gpt4 key购买 nike

如何让嵌入式 tomcat 通过 logback 写入日志?我找到了一些关于使用带有 log4j 的独立 tomcat 的信息。但是嵌入式 tomcat 和 logback 的设置看起来如何?

这些是 Maven 依赖项:

<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>${logback.version}</version>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-core</artifactId>
<version>${tomcat.version}</version>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-logging-juli</artifactId>
<version>${tomcat.version}</version>
</dependency>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-logging-log4j</artifactId>
<version>${tomcat.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
<version>${sl4j.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jul-to-slf4j</artifactId>
<version>${sl4j.version}</version>
</dependency>

我知道 Spring Boot 会自动执行 tomcat 日志记录集成。但在这种情况下,我不能使用 Spring。

最佳答案

Tomcat 8 有一个 ServiceLoader基于 discovery mechanism这使您可以部署自己的记录器实现。

只需在委托(delegate)给 Logback/SLF4J 的类中实现 org.apache.juli.logging.Log 并将类名放入 META-INF/services/org.apache 中。 juli.logging.Log 类路径中的文件。然后 Tomcat 将通过您的类登录。

import org.apache.juli.logging.Log;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;


public class DelegateToSlf4jLogger implements Log {
private final Logger logger;

// constructor required by ServiceLoader
public DelegateToSlf4jLogger() {
logger = null;
}

public DelegateToSlf4jLogger(String name){
logger = LoggerFactory.getLogger(name);
}

@Override
public boolean isDebugEnabled() {
return logger.isDebugEnabled();
}

@Override
public boolean isErrorEnabled() {
return logger.isErrorEnabled();
}

@Override
public boolean isFatalEnabled() {
return logger.isErrorEnabled();
}

@Override
public boolean isInfoEnabled() {
return logger.isInfoEnabled();
}

@Override
public boolean isTraceEnabled() {
return logger.isTraceEnabled();
}

@Override
public boolean isWarnEnabled() {
return logger.isWarnEnabled();
}

@Override
public void trace(Object message) {
logger.debug(String.valueOf(message));
}

@Override
public void trace(Object message, Throwable t) {
logger.debug(String.valueOf(message), t);
}

@Override
public void debug(Object message) {
logger.debug(String.valueOf(message));
}

@Override
public void debug(Object message, Throwable t) {
logger.debug(String.valueOf(message), t);
}

@Override
public void info(Object message) {
logger.info(String.valueOf(message));
}

@Override
public void info(Object message, Throwable t) {
logger.info(String.valueOf(message), t);
}

@Override
public void warn(Object message) {
logger.warn(String.valueOf(message));
}

@Override
public void warn(Object message, Throwable t) {
logger.warn(String.valueOf(message), t);
}

@Override
public void error(Object message) {
logger.error(String.valueOf(message));
}

@Override
public void error(Object message, Throwable t) {
logger.error(String.valueOf(message), t);
}

@Override
public void fatal(Object message) {
logger.error(String.valueOf(message));
}

@Override
public void fatal(Object message, Throwable t) {
logger.error(String.valueOf(message), t);
}
}

关于tomcat - 通过 logback/sl4j 进行嵌入式 Tomcat 日志记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41281520/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com