基于Spring Boot的Logback日志轮转配置详解

2025-05-29 0 82

在生产环境下,日志是最好的问题调试和跟踪方法,因此日志的地位是十分重要的。我们平时经常使用的log4j,slf4j,logback等等,他们的配置上大同小异。这里就结合spring boot配置一下logback日志

默认最简单的配置

默认情况下,如果对日志没有特殊处理,可以直接基于application.properties进行配置。

常用的参数有:

?

1
logging.level

配置日志的级别

?

1

2
logging.file

logging.path

这两个参数只能配置一个生效,一个是文件(可以有绝对路径或者相对路径);另一个是路径,文件的名称会默认为spring.log

日志默认按照大小进行切分,由于我这边没有产生那么大的文件,因此没有做实验。

这种方法最简单,但是不能处理那种复杂的日志轮转的机制。比如没天一个文件这种需求,因此可以考虑使用独立的日志文件进行配置:

使用独立的配置文件配置

如果有复杂的需求,可以像其他普通的web应用一样,配置独立的logback.xml:

首先注意的是这个文件必须放在resources目录下(我这边发现,如果通过logging.config指向另一个目录下的logback.xml会在程序启动时报错,报无法解析该xml。猜想可能是在其他目录下的xml都被当做spring的配置或者有xml schema信息的配置,单纯的logback.xml它不认识)

基于Spring Boot的Logback日志轮转配置详解

然后在application.properties文件中加入:

?

1

2
# 配置logback

logging.config=classpath:logback-spring.xml

即可。

注意如果是logging.config=classpath:xxxx/logback-spring.xml,就不行了哈!我试过好多次!

配置的内容基本可以参考下面的来:

?

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

35

36

37

38

39
<?xml version="1.0" encoding="utf-8"?>

<configuration>

<!-- 属性文件 -->

<property name="processname" value="xxx"/>

<property name="logdir" value="/opt/logs/xxx"/>

<!-- 默认的控制台日志输出,一般生产环境都是后台启动,这个没太大作用 -->

<appender name="stdout" class="ch.qos.logback.core.consoleappender">

<!--<encoding>utf-8</encoding>-->

<layout class="ch.qos.logback.classic.patternlayout">

<pattern>%date [%thread] %-5level %logger{50}:%l - %msg%n</pattern>

</layout>

</appender>

<!-- 配置文件轮转 -->

<appender name="logfile" class="ch.qos.logback.core.rolling.rollingfileappender">

<!--<encoding>utf-8</encoding>-->

<file>${logdir}/service.log</file>

<rollingpolicy class="ch.qos.logback.core.rolling.timebasedrollingpolicy">

<filenamepattern>${logdir}/history/service.%d{yyyy-mm-dd}.log.gz</filenamepattern>

<maxhistory>30</maxhistory>

</rollingpolicy>

<layout class="ch.qos.logback.classic.patternlayout">

<pattern>%date [%thread] %-5level %logger{50}:%l - %msg%n</pattern>

</layout>

</appender>

<!-- 修改其他包的日志输出级别 -->

<logger name="org.apache.zookeeper">

<level value="warn"/>

</logger>

<!-- root 默认日志配置 , 注意这里的级别哈!小心生产环境用debug,压爆你的磁盘!-->

<root level="info">

<appender-ref ref="logfile"/>

<appender-ref ref="stdout"/>

</root>

</configuration>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

原文链接:http://www.cnblogs.com/xing901022/p/7453909.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 基于Spring Boot的Logback日志轮转配置详解 https://www.kuaiidc.com/114271.html

相关文章

发表评论
暂无评论