Logback日志基础配置
logback日志配置有很多介绍,但是有几个非常基础的,容易忽略的。下面是最简单的一个配置,注意加粗的描述
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
<? 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方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
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 ;
}
}
|
二、配置日志文件
1
2
3
4
5
6
7
8
9
10
11
|
< 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 >
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://www.cnblogs.com/acm-bingzi/p/logback.html