有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java使用log4j在一行上获取多个日志

我正在使用org。阿帕奇。log4j。Logger和我经常在日志中看到这样的行:

2013-06-09T00:06:00,092 data data data dat2013-06-09T00:06:10,253 data data2013-06-09T00:06:16,202 data d2013-06-09T00:06:20,750 data data data data

我希望看到的是:

2013-06-09T00:06:00,092 data data data data
2013-06-09T00:06:10,253 data data data data
2013-06-09T00:06:16,202 data data data data
2013-06-09T00:06:20,750 data data data data

也就是说,多个日志行挤在一行上,日志信息被覆盖。我不知道我做错了什么,所以我想知道(A)这是否是显而易见的事情,或者(B)任何可以帮助我解决这个问题的指针

我的logger类如下所示:

public class MyLogger {
    private final org.apache.log4j.Logger log = org.apache.log4j.Logger.getLogger("com.example.mylog");

    public void info(String info){
        synchronized (log){
            log.info(info);
        }
    }
}

我是这样使用的:

private CallsLogger callsLogger;
/* ... */
myLogger.info(String.format("%s\t%s\t%s\t%s", "data", "data", "data", "data"));

我每天记录大约40000个事件,其中大约200个有格式错误的行,每行有2到11个单独的事件

我的log4j。xml看起来像这样:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "http://logging.apache.org/log4j/docs/api/org/apache/log4j/xml/log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    <appender name="mylog" class="org.apache.log4j.rolling.RollingFileAppender">
        <rollingPolicy class="org.apache.log4j.rolling.TimeBasedRollingPolicy">
            <param name="FileNamePattern" value="logs/mylog.log.%d.gz"/>
        </rollingPolicy>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern"
                   value="%d{yyyy-MM-dd'T'HH:mm:ss,SSS}\t%m%n"/>
        </layout>
    </appender>
    <logger name="com.example.mylog" additivity="false">
        <level value="INFO"/>
        <appender-ref ref="mylog"/>
    </logger>
    <root>
        <priority value="ERROR"/>
        <appender-ref ref="appender"/>
    </root>
</log4j:configuration>

非常感谢您的帮助


共 (2) 个答案

  1. # 1 楼答案

    使用像这样的类

    public class MyPatternLayout extends PatternLayout {
    ...
    public String format(LoggingEvent pEvent) {
        return super.format(pEvent).replace('\n', ' ') + '\n';
    }
    ...
    

    这将从要记录的字符串中删除所有\n,然后在行尾添加一个

    在log4j config xml中使用:

    <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
    ...
    <layout class="....MyPatternLayout">
    ...
    </layout>
    </appender>
    
  2. # 2 楼答案

    <param name="ConversionPattern"
                   value="%d{yyyy-MM-dd'T'HH:mm:ss,SSS} - %m%n"/>
    

    请尝试以上模式而不使用\t