logback系列之八:自定义Pattern模板

原创 2016年08月29日 14:28:24
创建自定义格式转换符有两步:

1.写一个转换器类,继承ClassicConvert
package com.cj.log;  
  
import ch.qos.logback.classic.pattern.ClassicConverter;  
import ch.qos.logback.classic.spi.ILoggingEvent;  
  
public class IpConvert extends ClassicConverter {  
  
    @Override  
    public String convert(ILoggingEvent event) {  
        return "10.10.10.10";  
    }  
}  
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源码:
public class PatternLayout extends PatternLayoutBase<ILoggingEvent> {  
  public static final Map<String, String> defaultConverterMap = new HashMap<String, String>();  
  static {  
    defaultConverterMap.putAll(Parser.DEFAULT_COMPOSITE_CONVERTER_MAP);  
    defaultConverterMap.put("d",DateConverter.class.getName());  
    defaultConverterMap.put("date",DateConverter.class.getName());  
    defaultConverterMap.put("r",RelativeTimeConverter.class.getName());  
    defaultConverterMap.put("relative",RelativeTimeConverter.class.getName());  
     ...  
现在只需在这个static方法快里加上一句:
defaultConverterMap.put("ip",IpConvert.class.getName());
即可。"ip"是转换的字符,IpConvert是上面定义的转换器类。但如何添加进去呢?下面便是一种实现方案:

首先,定义一个类,该类继承PatternLayout.java:
package com.cj.log;  
import ch.qos.logback.classic.PatternLayout;  
public class MyPatternLayout extends PatternLayout {  
    static {  
        defaultConverterMap.put("ip",IpConvert.class.getName());  
    }  
}  
直接调用父类的属性,将自定义的转换符添加进去。IpConvert便是上面已实现的转换器。

之后,便是在logback.xml中配置我们自定义的PatternLayout:
<!-- 日志输出格式 -->  
<layout class="com.cj.log.MyPatternLayout">  
      <Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %ip [%thread] %-5level %logger{36} -%msg%n</Pattern>  
</layout> 
原先的layout的class类为"ch.qos.logback.classic.PatternLayout",这里换成我们自定义的即可。

通过上述两种方案,便可实现自定义模板的功能。这种功能使用的一种场景便是在集群的环境下进行日志的分析,通常分析异常日志的时候,并不能准确定位到底是哪台主机上的哪个server出了错,如果添加了ip地址信息到日志中去,那么日志分析工作讲会变得更加准确高效。如果有类似于监控平台这样的系统,那么便可将所有的异常日志统一进行分析,只需在输出中定义一些类似于主机ip、系统应用id之类的区别的变量,这样处理的好处自然不言而喻。

版权声明:看完觉得好的。请留个脚印,证明你来过 举报

相关文章推荐

logback高级特性使用(二) 自定义Pattern模板

自定义Pattern模板 创建自定义格式转换符有两步: 1.写一个转换器类,继承ClassicConvert 示例代码: [java] ...

Log4J中使用自定义LoggingEvent

最近在做项目时,碰到一个很头疼的问题,需要扩展log4J的入口。在入口处,传递一些系统参数,给log4J处理。例如日志信息入库操作。         查看log4j的源代码后发现,在log4J中,是用...
  • gyd1
  • gyd1
  • 2008-06-24 20:12
  • 5023

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

logback系列之八:自定义Pattern模板

创建自定义格式转换符有两步: 1.写一个转换器类,继承ClassicConvert package com.cj.log; import ch.qos.logback.class...

logback日志配置

logback日志配置 ========================================================================================...

logback 自定义

Overview自定义Converter,通过conversionRule或者layout实现注入 常规使用Logback的方式不在本篇wiki的范围内 本文旨在解决我写的common_util....

Pyqt5系列(八)-自定义信号

PyQt5已经自动定义了很多QT内建的信号。但是在实际的使用中为了灵活使用信号与槽机制,我们可以根据需要自定义signal。可以使用pyqtSignal()方法定义新的信号,新的信号作为类的属性。

ecshop如何添加设置模板新增页面

第一步: 把根目录下 category.php 这个文件复制多一个文件,文件名自己起吧,我就以category2.php为例 同样的方法打开themes\default文件夹,category...

myEclipse使用自定义模板

No.1: 关闭MyEclipse,找到文件MyEclipse\Common\plugins\com.genuitec.eclipse.wizards_9.0.0.me201108091322....

Android Studio自定义模板 做开发竟然可以如此轻松 - 前篇

1.概述  最近有很多人反馈,有些哥们不喜欢看文字性的东西,还有一些哥们根本就不知道我在搞啥子,那么以后我就采用博客加视频的方式,我们可以选择看视频讲解:http://pan.baidu.com/s/...

Android Studio自定义模板

我们平时新建一个Activity一般都会建一个空的Activity ,模板名字:Empty Activity ,当然还有其他的模板,我们有没有想过,我们自己可以自定义这些模板,这样我们常用的布局代码可...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)