2017-08-10 70 views
1

我将显示log4j2与JSONLayout相同的消息上的对象。 例如我的配置是:当JSONLayout添加json对象到log4j2时

猫log4j2.xml

<?xml version="1.0" encoding="UTF-8"?> 
<Configuration status="INFO"> 
<Appenders> 
    <Console name="Console" target="SYSTEM_OUT"> 
     <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> 
    </Console> 
    <File name="Json" fileName="/home/jeus/log/loggerjson/main.log" bufferedIO="true" advertiseURI="file://home/jeus/log/loggerjson/main1.log" advertise="true"> 
     <JSONLayout compact="true" locationInfo="true" complete="false" eventEol="true" properties="true" propertiesAsList="true"/> 
    </File>  
</Appenders> 
<Loggers> 
    <Root level="info"> 
     <AppenderRef ref="Json"/> 
    </Root> 
</Loggers> 

我出去把输出:

猫的/ home/JEUS /日志/ loggerjson/main.log

{ 
"timeMillis":1502359773290, 
"thread":"main", 
"level":"INFO", 
"loggerName":"com.jeus.logger.json.loggerjson.Main", 
"message":"This message is a raw", 
"endOfBatch":false, 
"loggerFqcn":"org.apache.logging.log4j.spi.AbstractLogger", 
"contextMap":[ ], 
"threadId":1, 
"threadPriority":5, 
"source":{ 
    "class":"com.jeus.logger.json.loggerjson.Main", 
    "method":"main", 
    "file":"Main.java", 
    "line":61 
     } 
} 

我添加了一个JSON对象登录,但不显示在消息中的JSON对象,并表明,\”性格特征

JSON对象:

{"line_id": 12,"play_name":"Jeus"} 

我的日志代码:

import org.apache.logging.log4j.LogManager; 
import org.apache.logging.log4j.Logger; 

public class Main { 

     private static final Logger LOGGER = LogManager.getLogger(Main.class); 

     public static void main(String[] args) { 


      String message = "{\"line_id\": 12,\"play_name\": \"Jeus\"}"; 
      LOGGER.info(message); 

     } 
} 

输出为:

{ 
"timeMillis":1502361394238, 
"thread":"main", 
"level":"INFO", 
"loggerName":"com.jeus.logger.json.loggerjson.Main", 
"message":"{\"line_id\": 12,\"play_name\": \"Jeus\"}", 
"endOfBatch":false, 
"loggerFqcn":"org.apache.logging.log4j.spi.AbstractLogger", 
"contextMap":[ 

], 
"threadId":1, 
"threadPriority":5, 
"source":{ 
    "class":"com.jeus.logger.json.loggerjson.Main", 
    "method":"main", 
    "file":"Main.java", 
    "line":62 
    } 
} 

,但我会显示消息作为一个JSON对象相同的:

"message":{"line_id": 12,"play_name":"Jeus"}, 
+0

可能有办法做到这一点,不知道。请在log4j用户邮件列表上询问完整的Log4j2社区的输入信息。 –

+0

我认为它会在“(双引号)之前显示\(反斜杠),否则,生成的日志文件将不会是有效的JSON文件。 –

+0

另一个原因是log4j使用Jackson以JSON格式记录日志消息,如果你写json输出流中的字符串,反斜杠将在那里以双引号标记。 –

回答

1

这似乎并不可能与做内置JsonLayout。无论我尝试什么,它只是在字段上做一个toString,而不是正确地序列化它。

一个解决方案是使用PatternLayout并将其格式化为JSON。

log4j.appender.frontEndAudit.layout=org.apache.log4j.PatternLayout 
log4j.appender.frontEndAudit.layout.ConversionPattern={"timestamp": 
"%d{MM/dd/yyyy HH:mm:ss:SSSS}", "class": "%C", "file": "%F", "level" : 
"%5p", "line_number" : "%L", "logger_name": "frontEndAuditLog", "mdc": 
"ipAddress": "%X{ipAddress}", "requestId":"%X{requestId}", 
"sessionId":"%X{sessionId}"}, "message": %m, "method": "%M", 
"source_host":"%X{sourceHost}", "thread_name": "%t" }%n 

这对log4j1但相同的概念将工作log4j2