停止tomcat写入stdout和stderror

时间:2016-07-01 05:20:20

标签: java tomcat logging docker fluentd

我们使用docker。我们使用流利的作为我们的docker容器的日志记录驱动程序。我们使用tomcat来提供java应用程序。当java应用程序中抛出异常时,我们使用log4j来处理该异常。为了控制日志记录,我根据该页面上的说明https://tomcat.apache.org/tomcat-6.0-doc/logging.html在tomcat中安装了log4j。这是我正在使用的配置。

log4j.rootLogger = INFO, CATALINA

# Define all the appenders
log4j.appender.CATALINA = org.apache.log4j.DailyRollingFileAppender
log4j.appender.CATALINA.File = ${catalina.base}/logs/catalina
log4j.appender.CATALINA.Append = true
log4j.appender.CATALINA.Encoding = UTF-8
# Roll-over the log once per day
log4j.appender.CATALINA.DatePattern = '.'yyyy-MM-dd'.log'
log4j.appender.CATALINA.layout = org.apache.log4j.PatternLayout
log4j.appender.CATALINA.layout.ConversionPattern = stewart %d [%t] %-5p %c- %m%n

log4j.appender.LOCALHOST = org.apache.log4j.DailyRollingFileAppender
log4j.appender.LOCALHOST.File = ${catalina.base}/logs/localhost
log4j.appender.LOCALHOST.Append = true
log4j.appender.LOCALHOST.Encoding = UTF-8
log4j.appender.LOCALHOST.DatePattern = '.'yyyy-MM-dd'.log'
log4j.appender.LOCALHOST.layout = org.apache.log4j.PatternLayout
log4j.appender.LOCALHOST.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

log4j.appender.MANAGER = org.apache.log4j.DailyRollingFileAppender
log4j.appender.MANAGER.File = ${catalina.base}/logs/manager
log4j.appender.MANAGER.Append = true
log4j.appender.MANAGER.Encoding = UTF-8
log4j.appender.MANAGER.DatePattern = '.'yyyy-MM-dd'.log'
log4j.appender.MANAGER.layout = org.apache.log4j.PatternLayout
log4j.appender.MANAGER.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

log4j.appender.HOST-MANAGER = org.apache.log4j.DailyRollingFileAppender
log4j.appender.HOST-MANAGER.File = ${catalina.base}/logs/host-manager
log4j.appender.HOST-MANAGER.Append = true
log4j.appender.HOST-MANAGER.Encoding = UTF-8
log4j.appender.HOST-MANAGER.DatePattern = '.'yyyy-MM-dd'.log'
log4j.appender.HOST-MANAGER.layout = org.apache.log4j.PatternLayout
log4j.appender.HOST-MANAGER.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

# log4j.appender.CONSOLE = org.apache.log4j.ConsoleAppender
# log4j.appender.CONSOLE.Encoding = UTF-8
# log4j.appender.CONSOLE.layout = org.apache.log4j.PatternLayout
# log4j.appender.CONSOLE.layout.ConversionPattern = %d [%t] %-5p %c- %m%n

# Configure which loggers log to which appenders
log4j.logger.org.apache.catalina.core.ContainerBase.[Catalina].[localhost] = INFO, LOCALHOST
log4j.logger.org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/manager] = INFO, MANAGER
log4j.logger.org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/host-manager] = INFO, HOST-MANAGER

问题在于记录的每个错误堆栈跟踪仍然写入stderr。这会导致我们的日志记录平台将日志消息写入其中两次。什么是阻止所有堆栈跟踪写入stderr的最佳方法?

1 个答案:

答案 0 :(得分:0)

执行此操作的一种方法是抑制错误输出。

 System.setErr(null);

我正在使用spring,我使用PostConstruct注释在启动时运行此代码。

import javax.annotation.PostConstruct;
import org.springframework.context.annotation.Configuration;

@Configuration
public class SurpressLogging {

    @PostConstruct
    public void err() {
        System.setErr(null);
    }
}