一文读懂Logback的配置

开发 前端
为啥想着写这个呢?是这样,小六六每次搭建系统的时候,都会涉及到这块的配置嘛,然后我发现我搭建了这么多次的系统,大部分的情况下,竟然是copy来完成的,然后这次搭建的过程中,又对这些配置又了点理解,所以打算给大家分享分享一些关键的点,让大家多Java 项目的日志有一些更加深入的理解吧!

[[421672]]

前言

文本已收录至我的GitHub仓库,欢迎Star:https://github.com/bin392328206/six-finger

种一棵树最好的时间是十年前,其次是现在

絮叨

为啥想着写这个呢?是这样,小六六每次搭建系统的时候,都会涉及到这块的配置嘛,然后我发现我搭建了这么多次的系统,大部分的情况下,竟然是copy来完成的,然后这次搭建的过程中,又对这些配置又了点理解,所以打算给大家分享分享一些关键的点,让大家多Java 项目的日志有一些更加深入的理解吧!当然这边文章也得给大家清晰的理解logback的配置吧!尽量写的直白点!文章打算冲以下几个方面来描述

  • 官网文档
  • logback.xml常用配置详解
  • 一个小案例加深对配置的理解
  • logback.xml的参考配置(实战)
  • 开发时,小六六自己的一些特殊的用法(实战)

参考的文档

开始就先给大家给贴下参考的文档吧!不过我觉得你应该不会去看,哈哈。我也是一样的,看不下去官方文档

logback.xml常用配置详解

常用节点结构图:

相信大家对这个图应该不陌生,就是我们再spring-logback.xml里面要配置的文件就是这几个配置,下面我先来给大家讲讲细节

根节点 configuration

包含下面三个属性

  • scan: 当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true。
  • scanPeriod: 设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。
  • debug: 当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。
  1. <configuration scan="true" scanPeriod="60 seconds" debug="false">  
  2.     <!--其他配置省略-->  
  3. </configuration>  

子节点 appender

它的作用是负责写日志的组件,它有两个必要属性name和class。name指定appender名称,class指定appender的全限定名。

下面小六六带大家来看看我们常见的几种appender吧!工作上肯定用的到的

ConsoleAppender 把日志输出到控制台

encoder:对日志进行格式化。

  1. <appender name="console" class="ch.qos.logback.core.ConsoleAppender"
  2.    <encoder> 
  3.       <pattern>${CONSOLE_LOG_PATTERN}</pattern> 
  4.    </encoder> 
  5. </appender> 

 

 

FileAppender:把日志添加到文件

  • file:被写入的文件名,可以是相对目录,也可以是绝对目录,如果上级目录不存在会自动创建,没有默认值。
  • append:如果是 true,日志被追加到文件结尾,如果是 false,清空现存文件,默认是true。
  • encoder:对记录事件进行格式化。
  • prudent:如果是 true,日志会被安全的写入文件,即使其他的FileAppender也在向此文件做写入操作,效率低,默认是 false。
  1. <configuration>  
  2.       <appender name="FILE" class="ch.qos.logback.core.FileAppender">  
  3.         <file>testFile.log</file>  
  4.         <append>true</append>  
  5.         <encoder>  
  6.           <pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>  
  7.         </encoder>  
  8.       </appender>  
  9.  
  10.       <root level="DEBUG">  
  11.       <appender-ref ref="FILE" />  
  12.       </root>  
  13.   </configuration> 

 

 

 

 

RollingFileAppender 滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将日志记录到其他文件 这个小六六觉得是用的最多的一个了

  • file:被写入的文件名,可以是相对目录,也可以是绝对目录,如果上级目录不存在会自动创建,没有默认值。
  • append:如果是 true,日志被追加到文件结尾,如果是 false,清空现存文件,默认是true。
  • rollingPolicy:当发生滚动时,决定RollingFileAppender的行为,涉及文件移动和重命名。属性class定义具体的滚动策略类

class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy":最常用的滚动策略,它根据时间来制定滚动策略,既负责滚动也负责出发滚动。

  1. <appender name="BILogger_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"
  2.    <file>${log.path}/dataBi.dat</file> 
  3.    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"
  4.       <fileNamePattern>${log.path}/dataBi.dat.%d{yyyyMMdd}.gz</fileNamePattern> 
  5.       <maxHistory>30</maxHistory> 
  6.    </rollingPolicy> 
  7.    <encoder> 
  8.       <charset>UTF-8</charset> 
  9.       <pattern>%date|%msg%n</pattern> 
  10.    </encoder> 
  11. </appender> 

 

 

class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy":查看当前活动文件的大小,如果超过指定大小会告知RollingFileAppender 触发当前活动文件滚动

  1. <appender name="debug" class="ch.qos.logback.core.rolling.RollingFileAppender"
  2.    <file>${log.path}/debug.log</file> 
  3.    <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"
  4.       <fileNamePattern>${log.path}/%d{yyyy-MM, aux}/debug.%d{yyyy-MM-dd}.%i.log.gz</fileNamePattern> 
  5.       <maxFileSize>50MB</maxFileSize> 
  6.       <maxHistory>30</maxHistory> 
  7.    </rollingPolicy> 
  8.    <encoder> 
  9.       <pattern>%date [%thread] %-5level [%logger{50}] %file:%line - %msg%n</pattern> 
  10.    </encoder> 
  11. </appender> 

 

 

子节点 logger

用来设置某一个包或具体的某一个类的日志打印级别、以及指定。

  • logger仅有一个name属性,一个可选的level和一个可选的addtivity属性
  • 可以包含零个或多个元素,标识这个appender将会添加到这个logger。
  • name: 用来指定受此loger约束的某一个包或者具体的某一个类。
  • level: 用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL和OFF,还有一个特殊值INHERITED或者同义词NULL,代表强制执行上级的级别。如果未设置此属性,那么当前loger将会继承上级的级别。
  • addtivity: 是否向上级logger传递打印信息。默认是true。可以包含零个或多个appender-ref素,标识这个appender将会添加到这个logger。
  1. <!--  logger name 和spring配置一致  --> 
  2. <logger name="BILogger" level="INFO" additivity="true"
  3.    <appender-ref ref="BILogger_FILE" /> 
  4. </logger> 

像我们的bi日志,一般这种标准化,流程化的日志。

子节点root

它也是logger元素,但是它是根loger,是所有的上级。只有一个level属性,因为name已经被命名为"root",且已经是最上级了。

  1. <root level="INFO"
  2.    <appender-ref ref="console"/> 
  3.    <appender-ref ref="debug"/> 
  4.    <appender-ref ref="error"/> 
  5. </root> 

好了,上面就是我们比较重要的几个元素了,还有一两个小元素的话,小六六这边就没给大家看了。

logback.xml配置示例

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <configuration debug="false"
  3.  
  4.     <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径--> 
  5.     <property name="LOG_HOME" value="/home" /> 
  6.  
  7.     <!--控制台日志, 控制台输出 --> 
  8.     <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"
  9.         <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"
  10.             <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度,%msg:日志消息,%n是换行符--> 
  11.             <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern> 
  12.         </encoder> 
  13.     </appender> 
  14.  
  15.     <!--文件日志, 按照每天生成日志文件 --> 
  16.     <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"
  17.         <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"
  18.             <!--日志文件输出的文件名--> 
  19.             <FileNamePattern>${LOG_HOME}/TestWeb.log.%d{yyyy-MM-dd}.log</FileNamePattern> 
  20.             <!--日志文件保留天数--> 
  21.             <MaxHistory>30</MaxHistory> 
  22.         </rollingPolicy> 
  23.         <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"
  24.             <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符--> 
  25.             <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern> 
  26.         </encoder> 
  27.         <!--日志文件最大的大小--> 
  28.         <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"
  29.             <MaxFileSize>10MB</MaxFileSize> 
  30.         </triggeringPolicy> 
  31.     </appender> 
  32.  
  33.     <!-- show parameters for hibernate sql 专为 Hibernate 定制 --> 
  34.     <logger name="org.hibernate.type.descriptor.sql.BasicBinder" level="TRACE" /> 
  35.     <logger name="org.hibernate.type.descriptor.sql.BasicExtractor" level="DEBUG" /> 
  36.     <logger name="org.hibernate.SQL" level="DEBUG" /> 
  37.     <logger name="org.hibernate.engine.QueryParameters" level="DEBUG" /> 
  38.     <logger name="org.hibernate.engine.query.HQLQueryPlan" level="DEBUG" /> 
  39.  
  40.     <!--myibatis log configure--> 
  41.     <logger name="com.apache.ibatis" level="TRACE"/> 
  42.     <logger name="java.sql.Connection" level="DEBUG"/> 
  43.     <logger name="java.sql.Statement" level="DEBUG"/> 
  44.     <logger name="java.sql.PreparedStatement" level="DEBUG"/> 
  45.  
  46.     <!-- 日志输出级别 --> 
  47.     <root level="DEBUG"
  48.         <appender-ref ref="STDOUT" /> 
  49.         <appender-ref ref="FILE"/> 
  50.     </root> 
  51. </configuration> 

 

 

 

 

一个小案例加深对配置的理解

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <configuration debug="false"
  3.  
  4.     <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径--> 
  5.     <property name="LOG_HOME" value="/home" /> 
  6.  
  7.     <!--控制台日志, 控制台输出 --> 
  8.     <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"
  9.         <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"
  10.             <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度,%msg:日志消息,%n是换行符--> 
  11.             <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern> 
  12.         </encoder> 
  13.     </appender> 
  14.  
  15.     <!--文件日志, 按照每天生成日志文件 --> 
  16.     <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"
  17.         <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"
  18.             <!--日志文件输出的文件名--> 
  19.             <FileNamePattern>${LOG_HOME}/TestWeb.log.%d{yyyy-MM-dd}.log</FileNamePattern> 
  20.             <!--日志文件保留天数--> 
  21.             <MaxHistory>30</MaxHistory> 
  22.         </rollingPolicy> 
  23.         <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"
  24.             <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符--> 
  25.             <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern> 
  26.         </encoder> 
  27.         <!--日志文件最大的大小--> 
  28.         <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"
  29.             <MaxFileSize>10MB</MaxFileSize> 
  30.         </triggeringPolicy> 
  31.     </appender> 
  32.  
  33.     <!-- show parameters for hibernate sql 专为 Hibernate 定制 --> 
  34.     <logger name="org.hibernate.type.descriptor.sql.BasicBinder" level="TRACE" /> 
  35.     <logger name="org.hibernate.type.descriptor.sql.BasicExtractor" level="DEBUG" /> 
  36.     <logger name="org.hibernate.SQL" level="DEBUG" /> 
  37.     <logger name="org.hibernate.engine.QueryParameters" level="DEBUG" /> 
  38.     <logger name="org.hibernate.engine.query.HQLQueryPlan" level="DEBUG" /> 
  39.  
  40.     <!--myibatis log configure--> 
  41.     <logger name="com.apache.ibatis" level="TRACE"/> 
  42.     <logger name="java.sql.Connection" level="DEBUG"/> 
  43.     <logger name="java.sql.Statement" level="DEBUG"/> 
  44.     <logger name="java.sql.PreparedStatement" level="DEBUG"/> 
  45.  
  46.     <!-- 日志输出级别 --> 
  47.     <root level="DEBUG"
  48.         <appender-ref ref="STDOUT" /> 
  49.         <appender-ref ref="FILE"/> 
  50.     </root> 
  51. </configuration> 

 

 

 

 

开发时,小六六自己的一些特殊的用法(实战)

  • 第一个,就是在日志的时候加上traceId,这样的好处就是可以把日志收集到日志平台的时候,可以很好的查到整个流程
  1. <!--输出到日志平台 --> 
  2. <appender name="GELF" class="de.siegmar.logbackgelf.GelfUdpAppender"
  3.     <graylogHost>${graylogHost}</graylogHost> 
  4.     <graylogPort>${graylogPort}</graylogPort> 
  5.     <encoder class="de.siegmar.logbackgelf.GelfEncoder"
  6.         <originHost>${originHost}</originHost> 
  7.         <includeRawMessage>false</includeRawMessage> 
  8.         <includeMarker>true</includeMarker> 
  9.         <includeMdcData>true</includeMdcData> 
  10.         <includeCallerData>false</includeCallerData> 
  11.         <includeRootCauseData>false</includeRootCauseData> 
  12.         <includeLevelName>true</includeLevelName> 
  13.         <shortPatternLayout class="ch.qos.logback.classic.PatternLayout"
  14.             <pattern>%m%nopex</pattern> 
  15.         </shortPatternLayout> 
  16.         <fullPatternLayout class="ch.qos.logback.classic.PatternLayout"
  17.             <pattern>%m%n</pattern> 
  18.         </fullPatternLayout> 
  19.         <staticField>app_name:${appName}</staticField> 
  20.         <staticField>app_version:${appVersion}</staticField> 
  21.         <staticField>os_arch:${os.arch}</staticField> 
  22.         <staticField>os_name:${os.name}</staticField> 
  23.         <staticField>os_version:${os.version}</staticField> 
  24.         <staticField>uri:%X{uri}</staticField> 
  25.         <staticField>uid:%X{uid}</staticField> 
  26.         <staticField>ip:%X{ip}</staticField> 
  27.         <staticField>traceId:%X{traceId}</staticField> 
  28.     </encoder> 
  29. </appender> 

 

 

其中的原理是通过MDC实现的

  • 第二个就是,我们一些格式话的日志,做到数仓里面
  1. <!-- BI操作日志--> 
  2. <appender name="BILogger_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"
  3.    <file>${log.path}/dataBi.dat</file> 
  4.    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"
  5.       <fileNamePattern>${log.path}/dataBi.dat.%d{yyyyMMdd}.gz</fileNamePattern> 
  6.       <maxHistory>30</maxHistory> 
  7.    </rollingPolicy> 
  8.    <encoder> 
  9.       <charset>UTF-8</charset> 
  10.       <pattern>%date|%msg%n</pattern> 
  11.    </encoder> 
  12. </appender> 
  13. <!-- DI操作日志--> 
  14. <appender name="DILogger_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"
  15.    <file>${log.path}/dataDi.dat</file> 
  16.    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"
  17.       <fileNamePattern>${log.path}/dataDi.dat.%d{yyyyMMdd}.gz</fileNamePattern> 
  18.       <maxHistory>30</maxHistory> 
  19.    </rollingPolicy> 
  20.    <encoder> 
  21.       <charset>UTF-8</charset> 
  22.       <pattern>%date|%msg%n</pattern> 
  23.    </encoder> 
  24. </appender> 

 

 

类似于这种。。

结束

 

我是小六六,三天打鱼,两天晒网,今天就到这了哈!

 

责任编辑:武晓燕 来源: 六脉神剑的程序人生
相关推荐

2021-08-04 16:06:45

DataOps智领云

2023-12-22 19:59:15

2018-09-28 14:06:25

前端缓存后端

2022-09-22 09:00:46

CSS单位

2022-11-06 21:14:02

数据驱动架构数据

2022-10-20 08:01:23

2022-07-05 06:30:54

云网络网络云原生

2023-05-20 17:58:31

低代码软件

2021-12-29 18:00:19

无损网络网络通信网络

2023-11-27 17:35:48

ComponentWeb外层

2022-12-01 17:23:45

2022-07-26 00:00:03

语言模型人工智能

2023-11-21 09:41:00

缓存策略存储

2017-05-04 20:29:12

HTTP服务器TCP

2021-02-05 05:26:33

字节ASCII控制

2021-05-18 09:48:58

前端开发架构

2018-10-30 11:10:05

Flink数据集计算

2018-09-29 04:53:37

IoT网关物联网IoT

2024-01-03 08:54:17

Kubernetes策略工具

2023-11-20 14:58:30

人工智能AI Agents
点赞
收藏

51CTO技术栈公众号