博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
logback高级特性使用(二) 自定义Pattern模板
阅读量:4056 次
发布时间:2019-05-25

本文共 2185 字,大约阅读时间需要 7 分钟。

自定义Pattern模板

创建自定义格式转换符有两步:
1.写一个转换器类,继承ClassicConvert
示例代码:
[java]
  1. package com.cj.log;  
  2.   
  3. import ch.qos.logback.classic.pattern.ClassicConverter;  
  4. import ch.qos.logback.classic.spi.ILoggingEvent;  
  5.   
  6. public class IpConvert extends ClassicConverter {  
  7.   
  8.     @Override  
  9.     public String convert(ILoggingEvent event) {  
  10.         return "10.10.10.10";  
  11.     }  
  12. }  
2.在logback.xml中注册该转换器,并自定义转换符
注册:
<conversionRule conversionWord="ip" converterClass="com.cj.log.IpConvert" />
自定义ip转换符:
<Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}%ip [%thread] %-5level %logger{36} -% msg%n</Pattern>
经过这两步骤后,即可将自定义的ip转换符添加到输出模板当中了。
测试结果:
2013-04-01 15:25:16.887
 10.10.10.10 [main] ERROR c.s.f.log.normal.TestAppender
这里的10.10.10.10便是转换后的值了。
上面的步骤只是基本的自定义模板方法,不好的地方就是要在配置文件里注册,实际上只要模仿logback原生创建的方法把这个转换符加进去就可以了。可以看下PatternLayout.java源码:
[java]
  1. public class PatternLayout extends PatternLayoutBase<ILoggingEvent> {  
  2.   public static final Map<String, String> defaultConverterMap = new HashMap<String, String>();  
  3.   static {  
  4.     defaultConverterMap.putAll(Parser.DEFAULT_COMPOSITE_CONVERTER_MAP);  
  5.     defaultConverterMap.put("d",DateConverter.class.getName());  
  6.     defaultConverterMap.put("date",DateConverter.class.getName());  
  7.     defaultConverterMap.put("r",RelativeTimeConverter.class.getName());  
  8.     defaultConverterMap.put("relative",RelativeTimeConverter.class.getName());  
  9.      ...  
现在只需在这个static方法快里加上一句:
defaultConverterMap.put("ip",IpConvert.class.getName());
即可。"ip"是转换的字符,IpConvert是上面定义的转换器类。但如何添加进去呢?
下面便是一种实现方案:
首先,定义一个类,该类继承PatternLayout.java:
[java]
  1. package com.cj.log;  
  2. import ch.qos.logback.classic.PatternLayout;  
  3. public class MyPatternLayout extends PatternLayout {  
  4.     static {  
  5.         defaultConverterMap.put("ip",IpConvert.class.getName());  
  6.     }  
  7. }  
直接调用父类的属性,将自定义的转换符添加进去。IpConvert便是上面已实现的转换器。
之后,便是在logback.xml中配置我们自定义的PatternLayout:
[html]
  1. <!-- 日志输出格式 -->  
  2. <layout class="com.cj.log.MyPatternLayout">  
  3.       <Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %ip [%thread] %-5level %logger{36} -%msg%n</Pattern>  
  4. </layout>  
原先的layout的class类为"
ch.qos.logback.classic.PatternLayout",这里换成我们自定义的即可。
通过上述两种方案,便可实现自定义模板的功能。这种功能使用的一种场景便是在集群的环境下进行日志的分析,通常分析异常日志的时候,并不能准确定位到底是哪台主机上的哪个server出了错,如果添加了ip地址信息到日志中去,那么日志分析工作讲会变得更加准确高效。如果有类似于监控平台这样的系统,那么便可将所有的异常日志统一进行分析,只需在输出中定义一些类似于主机ip、系统应用id之类的区别的变量,这样处理的好处自然不言而喻。

转载地址:http://oweci.baihongyu.com/

你可能感兴趣的文章
Android2.1消息应用(Messaging)源码学习笔记
查看>>
Variable property attributes or Modifiers in iOS
查看>>
NSNotificationCenter 用法总结
查看>>
C primer plus 基础总结(一)
查看>>
剑指offer算法题分析与整理(三)
查看>>
mint/ubuntu安装搜狗输入法
查看>>
C++动态申请数组和参数传递问题
查看>>
opencv学习——在MFC中读取和显示图像
查看>>
JVM并发机制探讨—内存模型、内存可见性和指令重排序
查看>>
nginx+tomcat+memcached (msm)实现 session同步复制
查看>>
WAV文件解析
查看>>
WPF中PATH使用AI导出SVG的方法
查看>>
QT打开项目提示no valid settings file could be found
查看>>
Win10+VS+ESP32环境搭建
查看>>
android 代码实现圆角
查看>>
flutter-解析json
查看>>
android中shader的使用
查看>>
java LinkedList与ArrayList迭代器遍历和for遍历对比
查看>>
drat中构造方法
查看>>
JavaScript的一些基础-数据类型
查看>>