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"},
可能有办法做到这一点,不知道。请在log4j用户邮件列表上询问完整的Log4j2社区的输入信息。 –
我认为它会在“(双引号)之前显示\(反斜杠),否则,生成的日志文件将不会是有效的JSON文件。 –
另一个原因是log4j使用Jackson以JSON格式记录日志消息,如果你写json输出流中的字符串,反斜杠将在那里以双引号标记。 –