Logback日志基础及自定义配置代码实例

Logback日志基础配置

logback日志配置有很多介绍,但是有几个非常基础的,容易忽略的。下面是最简单的一个配置,注意加粗的描述

<?xml version="1.0" encoding="UTF-8"?>

<configuration debug="true" scan="true" scanPeriod="30 seconds">

<!--log.path定义的是局部变量,./logs指定的是相对路径下的文件夹logs-->

<property name="log.path" value="./logs"/>

<appender name="ROLLING-FILE-OUT" class="ch.qos.logback.core.rolling.RollingFileAppender">

<!--这里的文件名是不能使用正则表达式,只能是定死的名字,实现了很久-->

<file>${log.path}/errorlog.log</file>

<!-- 日志输出格式:%d表示日期时间,%thread表示线程名,%-5level:级别从左显示5个字符宽度

%logger{50} 表示logger名字最长50个字符,否则按照句点分割。 %msg:日志消息,%n是换行符 -->

<encoder>

<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>

</encoder>

<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">

<!-- 每天日志归档路径以及格式,可以不使用log后缀,%i:当文件大小超过maxFileSize时,按照i进行文件滚动,i从0开始滚动 -->

<FileNamePattern>${log.pat h}/errorlog.%d{yyyyMMdd}.log.%i.gz</FileNamePattern>

<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">

<maxFileSize>4096MB</maxFileSize>

</timeBasedFileNamingAndTriggeringPolicy>

<!--日志文件保留天数-->

<maxHistory>365</maxHistory>

</rollingPolicy>

</appender>

<!-- 日志级别-->

<root level="debug">   

<appender-ref ref="ROLLING-FILE-OUT"/>

</root>

</configuration>

在规范里,行结束符往往采用Linux结束符(\n),而不是上面那样的 %n。 这个\n ,使用txt文档查看,并没有换行

使用%的正则还有许许多多,比如如下:

<property name="CONSOLE_LOG_PATTERN" value="%date{yyyy-MM-dd HH:mm:ss} | %highlight(%-5level) | %yellow(%thread) | %green(%logger) | %msg%n"/>

再比如:%contextName 作用是 显示主机名

Logback日志自定义配置

即便如此,还是有很多想要的东西显示不了,这时就可自定义配置。比如我希望每条日志有个uuid类型的id,希望每条日志能打印ip地址

一、新建两个配置类,重写convert方法

package cn.jiashubing.config.logback;

import ch.qos.logback.classic.pattern.ClassicConverter;

import ch.qos.logback.classic.spi.ILoggingEvent;

import java.util.UUID;

public class LogIdConfig extends ClassicConverter {

@Override

public String convert(ILoggingEvent event) {

return UUID.randomUUID().toString().replaceAll("-", "");

}

}

package cn.jiashubing.config.logback;

import ch.qos.logback.classic.pattern.ClassicConverter;

import ch.qos.logback.classic.spi.ILoggingEvent;

import java.net.InetAddress;

import java.net.UnknownHostException;

public class IPLogConfig extends ClassicConverter {

@Override

public String convert(ILoggingEvent event) {

try {

return InetAddress.getLocalHost().getHostAddress();

} catch (UnknownHostException e) {

e.printStackTrace();

}

return null;

}

}

二、配置日志文件

<property name="log.path" value="./logs"/>

<conversionRule conversionWord="ip" converterClass="cn.jiashubing.config.logback.IPLogConfig" />

<conversionRule conversionWord="logid" converterClass="cn.jiashubing.config.logback.LogIdConfig" />

<appender name="ROLLING-FILE-OUT" class="ch.qos.logback.core.rolling.RollingFileAppender">       

<file>${log.path}/errorlog.log</file>       

<encoder>           

<pattern>[loglevel=%level] [timestamp=%d{yyyy-MM-dd HH:mm:ss}] [logid=%logid] [ip=%ip] [cmd=%msg] \n</pattern>       

</encoder>

...

</appender>

以上是 Logback日志基础及自定义配置代码实例 的全部内容, 来源链接: utcz.com/z/332091.html

回到顶部