log4j2的JsonLayout测试

本文记录了对log4j2的JsonLayout进行测试的过程,探讨其在分布式日志采集器中的潜在优势。通过JsonLayout,可以更方便地将日志映射到ElasticSearch并创建索引,简化字段处理。文中提到了log4j2与log4j1的区别,如不支持.log4j.properties配置文件,主要使用.xml或.json配置。还分享了一个简单的测试类示例及JSON输出格式,并指出使用JsonLayout需引入Jackson依赖。
摘要由CSDN通过智能技术生成

log4j2的JsonLayout测试

@(工程开发)

最近在开发通用的分布式日志采集器。碰到日志信息块的划分问题,尤其是碰到有异常堆栈的情况,需要做合并操作。当前我们的解决方案是使用日志块的起始时间来判断。有过萌生使用JsonLayout的想法,直接可以映射到ElasticSearch,方便创建索引,减少过多的字段切分。遂测试了log4j2的JsonLayout,网上资料还不多,简单的做下备忘。

log4j2相比于log4j版本1有了不少的变动,从maven的依赖看,使用的没有版本1的多。最主要的是log4j2不再支持log4j.properties的配置文件,主要使用log4j2.xml或者log4j2.json的配置方式。既然有xml,使用xml其实相对简单,毕竟有xsd文件,配置就可以免去太多的网上搜索。OK,废话少说,简单的xml配置可以如下:

<?xml version="1.0" encoding="UTF-8"?>  
<configuration status="OFF">  
  <appenders>  
    <Console name="Console" target="SYSTEM_OUT">  
      <JsonLayout/> <!--使用json格式输出-->
    </Console>  
  </appenders>  
  <loggers>  
    <root level="trace">  
      <appender-ref ref="Console"/>  
    </root>  
  </loggers>  
</configuration> 

简单的创建一个测试类:

package com.linjx.log4j.jsonpattern;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 测试JSON格式打印结果
 * @author linjiexing
 * @Date 2016年8月13日
 * @version 1.
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值