logback 自定义Pattern模板教程

网友投稿 426 2022-10-10


logback 自定义Pattern模板教程

配色板

"%black", "%red", "%green","%yellow","%blue", "%magenta","%cyan", "%white", "%gray","%boldRed","%boldGreen", "%boldYellow", "%boldBlue", "%boldMagenta","%boldCyan", "%boldWhite","%highlight"

例:%red(XX),则 XX 这两个字为红色

其它 %p 表示level,%t表示线程名

自定义Pattern模板

创建自定义格式转换符有两步:

1.写一个转换器类,继承ClassicConvert

示例代码:

public class IpConvert extends ClassicConverter {

@Override

public String convert(ILoggingEvent event) {

String ip = "10.10.10.10";

return ip;

}

}

2.在logback.xml中注册该转换器,并自定义转换符

注册:

自定义ip转换符:

%d{yyyy-MM-dd HH:mm:ss.SSS}%ip [%thread] %-5level %logger{36} -% msg%n

经过这两步FIwppTh骤后,即可将自定义的ip转换符添加到输出模板当中了。

测试结果:

2015-05-01 15:25:16.887 10.10.10.10 [main] INFO c.s.f.log.normal.TestAppender

这里的10.10.10.10便是转换后的值了。

上面的步骤只是基本的自定义模板方法,不好的地方就是要在配置文件里注册,实际上只要模仿logback原生创建的方法把这个转换符加进去就可以了。可以看下PatternLayout.java源码:

public class PatternLayout extends PatternLayoutBase {

public static final Map defaultConverterMap = new HashMap();

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:

import ch.qos.logback.classic.PatternLayout;

public class MyPatternLayout extends PatternLayout {

static {

defaultConverterMap.put("ip",IpConvert.class.getName());

}

}

直接调用父类的属性,将自定义的转换符添加进去。IpConvert便是上面已实现的转换器。

之后,便是在logback.xml中配置我们自定义的PatternLayout:

%d{yyyy-MM-dd HH:mm:ss.SSS} %ip [%thread] %-5level %logger{36} -%msg%n

原先的layout的class类为”ch.qos.logback.classic.PatternLayout”,这里换成我们自定义的即可。

通过上述两种方案,便可实现自定义模板的功能。这种功能使用的一种场景便是在集群的环境下进行日志的分析,通常分析异常日志的时候,并不能准确定位到底是哪台主机上的哪个server出了错,如果添加了ip地址信息到日志中去,那么日志分析工作讲会变得更加准确高效。

如果有类似于监控平台这样的系统,那么便可将所有的异常日志统一进行分析,只需在输出中定义一些类似于主机ip、系统应用id之类的区别的变量,这样处理的好处自然不言而喻。

以下是我实际用到logback的配置

value="%date{yyyy-MM-dd HH:mm:ss} %boldGreen(%ip) | %highlight(%-5level) | %boldYellow(%thread) | %boldGreen(%logger) | %msg%n"/>

value="===%d{yyyy-MM-dd HH:mm:ss.SSS} %ip %-5level %logger Line:%-3L - %msg%n"/>

${CONSOLE_LOG_PATTERN}

UTF-8

debug

SpringBootDemo

${LOG_PATH}/${APPDIR}/log_error.log

${LOG_PATH}/${APPDIR}/error/log-error-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

error

ACCEPT

DENY

${LOG_PATH}/${APPDIR}/log_warn.log

${LOG_PATH}/${APPDIR}/warn/log-warn-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

warn

ACCEPT

DENY

<file>${LOG_PATH}/${APPDIR}/log_info.log

${LOG_PATH}/${APPDIR}/info/log-info-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

info

ACCEPT

DENY

输出的日志为:

value="%date{yyyy-MM-dd HH:mm:ss} %boldGreen(%ip) | %highlight(%-5level) | %boldYellow(%thread) | %boldGreen(%logger) | %msg%n"/>

value="===%d{yyyy-MM-dd HH:mm:ss.SSS} %ip %-5level %logger Line:%-3L - %msg%n"/>

${CONSOLE_LOG_PATTERN}

UTF-8

debug

SpringBootDemo

${LOG_PATH}/${APPDIR}/log_error.log

${LOG_PATH}/${APPDIR}/error/log-error-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

error

ACCEPT

DENY

${LOG_PATH}/${APPDIR}/log_warn.log

${LOG_PATH}/${APPDIR}/warn/log-warn-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

warn

ACCEPT

DENY

<file>${LOG_PATH}/${APPDIR}/log_info.log

${LOG_PATH}/${APPDIR}/info/log-info-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

info

ACCEPT

DENY

输出的日志为:

value="===%d{yyyy-MM-dd HH:mm:ss.SSS} %ip %-5level %logger Line:%-3L - %msg%n"/>

${CONSOLE_LOG_PATTERN}

UTF-8

debug

SpringBootDemo

${LOG_PATH}/${APPDIR}/log_error.log

${LOG_PATH}/${APPDIR}/error/log-error-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

error

ACCEPT

DENY

${LOG_PATH}/${APPDIR}/log_warn.log

${LOG_PATH}/${APPDIR}/warn/log-warn-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

warn

ACCEPT

DENY

<file>${LOG_PATH}/${APPDIR}/log_info.log

${LOG_PATH}/${APPDIR}/info/log-info-%d{yyyy-MM-dd}.%i.log

2MB

true

${FILE_LOG_PATTERN}

utf-8

info

ACCEPT

DENY

输出的日志为:


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:认识安全测试之SQL注入(sql注入可以通过安全的输入校验机制来预防)
下一篇:Kali安装leviathan-大规模审计工具包
相关文章

 发表评论

暂时没有评论,来抢沙发吧~