服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|JavaScript|易语言|

服务器之家 - 编程语言 - JAVA教程 - 基于Spring Boot的Logback日志轮转配置详解

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

2021-01-21 13:35xingoo JAVA教程

本篇文章主要介绍了基于Spring Boot的Logback日志轮转配置详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

在生产环境下,日志是最好的问题调试和跟踪方法,因此日志的地位是十分重要的。我们平时经常使用的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>

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

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

延伸 · 阅读

精彩推荐
  • JAVA教程spring mail借助qq邮箱服务器发送邮件

    spring mail借助qq邮箱服务器发送邮件

    这篇文章主要介绍了spring mail借助qq邮箱服务器发送邮件的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...

    凌承一5022020-07-12
  • JAVA教程Struts2中Action中是否需要实现Execute方法

    Struts2中Action中是否需要实现Execute方法

    这篇文章主要介绍了Struts2中Action中是否需要实现Execute方法的相关资料,需要的朋友可以参考下 ...

    SimonMaxs2842020-04-09
  • JAVA教程谈谈变量命名规范的重要性

    谈谈变量命名规范的重要性

    下面小编就为大家带来一篇谈谈变量命名规范的重要性。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    jingxian1332020-07-27
  • JAVA教程学习Java多线程之同步

    学习Java多线程之同步

    这篇文章主要为大家详细介绍了Java多线程之同步,感兴趣的小伙伴们可以参考一下 ...

    刘望舒2472020-04-06
  • JAVA教程Java 获得文件的指纹

    Java 获得文件的指纹

    在文件上传到服务器的时候,我们希望能够获得文件的指纹以确定文件没有被篡改过。常用的算法最开始使用的是 MD5,随后随着技术的发展,MD5 算法已经...

    今日头条3132020-10-28
  • JAVA教程Java异常学习之自定义异常详解

    Java异常学习之自定义异常详解

    你的程序总有一天会崩溃掉,在崩溃掉的时候我们要知道它在哪,为了什么而崩溃掉,数据的保存或者丢失情况如何等问题。下面这篇文章主要给大家介绍...

    AlanLee(Java)4292020-11-22
  • JAVA教程Java文件操作类 File实现代码

    Java文件操作类 File实现代码

    这篇文章主要介绍了Java文件操作类 File实现代码,需要的朋友可以参考下...

    夏天de树下睡着了3802020-12-19
  • JAVA教程java 内部类的详解及实例

    java 内部类的详解及实例

    这篇文章主要介绍了 java 内部类的详解及实例的相关资料,这里提供了两种内部类的实现方法,并给出实例,需要的朋友可以参考下...

    fancheng6143732020-12-11