java - log4j 将标准输出重定向到 DailyRollingFileAppender

标签 java file redirect log4j stdout

我有一个使用 log4j 的 java 应用程序。

配置:

log4j.rootLogger=info, file

log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.File=${user.home}/logs/app.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d [%t] %c %p %m%n

所以所有日志语句都正确附加到文件中,但我丢失了标准输出和标准错误。如何将异常堆栈跟踪和系统输出重定向到每日滚动文件?

最佳答案

// I set up a ConsoleAppender in Log4J to format Stdout/Stderr
log4j.rootLogger=DEBUG, CONSOLE
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=[%t] %-5p %c - %m%n


// And I call this StdOutErrLog.tieSystemOutAndErrToLog() on startup

public class StdOutErrLog {

    private static final Logger logger = Logger.getLogger(StdOutErrLog.class);

    public static void tieSystemOutAndErrToLog() {
        System.setOut(createLoggingProxy(System.out));
        System.setErr(createLoggingProxy(System.err));
    }

    public static PrintStream createLoggingProxy(final PrintStream realPrintStream) {
        return new PrintStream(realPrintStream) {
            public void print(final String string) {
                realPrintStream.print(string);
                logger.info(string);
            }
        };
    }
}

关于java - log4j 将标准输出重定向到 DailyRollingFileAppender,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1200175/

相关文章:

java - Android模拟器无法加载应用程序

java - 从 Cloud Firestore 中的一个集合中获取所有文档?

java - 有意以 int 形式发送到另一个 Activity 的 ID 始终为零

Python,通过创建复制文件

c# - 中间件是否需要在 ASP.net 和 C# 中重定向到 HTTPS?

java - 在 Java Stream 中组合过滤器和映射

Java - 无法从文件中绘制图像

android - 如何检查 Android 中存在的文件没有损坏?

php - 禁用 wp-admin 到 wp-login 规范重定向(wordpress)

Wordpress 多站点 www 非 www 页面重定向失败