广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Logback的使用及如何配置
  • 644
分享到

Logback的使用及如何配置

2024-04-02 19:04:59 644人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录1 为什么选用Logback?2 Logback的配置3 Logback的输出格式4 Appender5 Logback使用过程中遇到的问题日志在项目开发过程的作用不言而喻,项目

日志项目开发过程的作用不言而喻,项目上线后,我们需要根据日志文件定位问题发生的位置以及产生的原因。以前在项目开发中,已经有前人在工程中配置过日志,所以完全不需要自己再进行日志的配置。这次在新的项目中自己来配置日志时,还是遇到了一些波折,下面慢慢道来。

1 为什么选用Logback?

目前,在SpringBoot工程体系中,使用较多的日志组件是Slf4j、Logback以及Log4j2。而Slf4j本身只是一个接口类,具体的实现还是由Logback或Log4j2来完成的。由于springboot自身就集成了Logback,默认使用的日志组件是Logback,Logback的体系结构具有足够的通用性,可以在不同的场景下使用。因此,在我们的DRS工程中,使用了Logback进行日志的打印。

目前,Logback包含三个部分:logback-core, logback-classic, logback-access。 Logback-core: 为其他两个模块奠定了基础 Logback-classic: 可以被同化为log4j的一个显著改进的版本,此外, logback-classic实现了slf4japi,因此您可以方便地在logback和其他日志框架(如log4j或log4j)之间来回切换java.util.logging文件 Logback-access: 集成了Servlet容器(如Tomcat和Jetty),以提供Http访问日志功能。

如果使用的是Springboot是2.4版本及以上,则不需要另外引入logback-core, logback-classic, logback-access和slf2j-api的依赖包的。

2 Logback的配置

首先,看一下我们在DRS工程中使用的Logback配置文件:


<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <property name="log.path" value="/duan/drs-server/logs" />
  <property name="log.pattern" value="%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n" />
 
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
      <pattern>${log.pattern}</pattern>
    </encoder>
  </appender>
 
  <!-- 系统debug日志输出 -->
  <appender name="FILE_DEBUG" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${log.path}/drs-server-debug.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <fileNamePattern>${log.path}/drs-server-debug.%d{yyyy-MM-dd}.log</fileNamePattern>
      <maxHistory>30</maxHistory>
    </rollingPolicy>
    <encoder>
      <pattern>${log.pattern}</pattern>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <level>DEBUG</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender>
 
  <!-- 系统info日志输出 -->
  <appender name="FILE_INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${log.path}/drs-server-info.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <fileNamePattern>${log.path}/drs-server-info.%d{yyyy-MM-dd}.log</fileNamePattern>
      <maxHistory>30</maxHistory>
    </rollingPolicy>
    <encoder>
      <pattern>${log.pattern}</pattern>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <level>INFO</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender>
 
  <!-- 系统warn日志输出 -->
  <appender name="FILE_WARN" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${log.path}/drs-server-warn.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <fileNamePattern>${log.path}/drs-server-warn.%d{yyyy-MM-dd}.log</fileNamePattern>
      <maxHistory>30</maxHistory>
    </rollingPolicy>
    <encoder>
      <pattern>${log.pattern}</pattern>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <level>WARN</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender>
 
  <!-- 系统error日志输出 -->
  <appender name="FILE_ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${log.path}/drs-server-error.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <fileNamePattern>${log.path}/drs-server-error.%d{yyyy-MM-dd}.log</fileNamePattern>
      <maxHistory>30</maxHistory>
    </rollingPolicy>
    <encoder>
      <pattern>${log.pattern}</pattern>
    </encoder>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <level>ERROR</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
  </appender>
 
  <logger name="com.nuonuo.middleware.drsserver" level="INFO" />
  <logger name="org.springframework" level="warn" />
 
  <root level="INFO">
    <appender-ref ref="STDOUT" />
    <appender-ref ref="FILE_DEBUG" />
    <appender-ref ref="FILE_INFO" />
    <appender-ref ref="FILE_WARN" />
    <appender-ref ref="FILE_ERROR" />
  </root>
</configuration>

说明:

属性 说明
log.path 定义日志文件的输出路径
log.pattern 定义日志文件输出格式
appender 定义了日志的输出文件,日志文件保留时长,使用何种模式输出,以及过滤规则。在上述文件中,分别针对DEBUG、INFO、WARN和ERROR日志进行了定义了四个Appender
logger 用来设置某一个类或某个包的日志打印级别。在上述配置中,我们将DRS工程的日志输出级别定义为INFO,那么,如果只想打印出DRS工程中的日志,则只需将打印级别level设置为WARN
root 是一个根logger,root下可以包含零个或多个appender。如果一个appender没有在root下引入,则不会生成对应的日志文件

3 Logback的输出格式

针对以上述配置中的格式进行说明:


%d{HH:mm:ss.SSS} [%thread] %-5level %logger{20} - [%method,%line] - %msg%n
字段 说明
%d{HH:mm:ss.SSS} 用于输出日志事件的日期,其中%d也可以替换成%date,该设置对应下图中的红色标记部分
[%thread] 输出对应的线程名。在上面的截图中可以看到,输出线程是主线程main
%-5level 输出日志级别,其中-5表示如果记录器名称长度小于5个字符,则右键填充空格
%logger{20} 输出日志事件起源处记录器的名称。其中20表示输出记录的名称长度限制,超过这个长度,记录器名将会进行缩写。但是,记录器名称中最右边的段从不缩写,即使其长度比“长度”选项长。其他段可以缩短到最多一个字符,但永远不会删除
[%method,%line] %method 输出发出日志记录请求的方法名称,%method也可替换成%M; %line——输出发出日志记录请求的行号,%line也可替换成%L
%msg 输出应用程序提供的与日志事件关联的消息。其中%msg也可替换成%m或%message
%n 输出平台相关的行分隔符字符

4 Appender

Appender子类包含Filter、Encoder、ConsoleAppender、FileAppender、以及RollingFileAppender。其类图关系如下所示。

顾名思义目标文件由file选项指定。如果该文件已存在,则根据append属性的值将其追加或截断。RollingFileAppender 扩展了FileAppender,具有滚动更新日志文件的功能。

类名 encoder immediateFlush target withJansi append file prudent rollingPolicy triggeringPolicy
OutputStreamAppender
ConsoleAppender
FileAppender - -
RollingFileAppender - -

OutputStreamAppender 这个类提供了其他附加程序构建的基本服务。该类包含两个属性设置: encoder—— 确定日志写入的编码格式。 immediateFlush——布尔值,默认为true, 立即刷新输出流可确保立即写出日志事件,并且在应用程序退出而未正确关闭附加器时不会丢失这些事件。 另一方面,将此属性设置为“false”可能会使日志吞吐量增加四倍。同样,如果immediateFlush设置为“false”,并且应用程序退出时appender未正确关闭,则尚未写入磁盘的日志事件可能会丢失。

ConsoleAppender 将日志附加在控制台上,其包含三个属性: encoder——略 target—— System.out或者 System.err字符串值之一 默认目标是 System.out withJansi——布尔值,默认false。 将withJansi设置为true将激活Jansi库,该库为windows机器上的ANSI颜色代码提供支持。在Windows主机上,如果此属性设置为true,则应将网址:org.fusesource.jansi:jansi:1.17“在类路径上进行设置。请注意,基于Unix的操作系统(如linuxMacosx)默认支持ANSI颜色代码。一般我们很少用到,使用默认值即可。

FileAppender 它将日志事件附加到文件中,其包含四个属性: append——布尔值,默认为true, 表示事件附加在现有文件的末尾。如果append为false,则任何现有文件都将被截断。 encoder——略 file—— 要写入的文件的名称, 如果文件不存在,则创建该文件。 如果文件的父目录不存在,FileAppender将自动创建它,包括任何必要但不存在的父目录。 prudent——布尔值,默认值为false。如果设置为true, FileAppender将安全地写入指定的文件,即使存在运行在不同JVM(可能运行在不同主机上)中的其他FileAppender实例。

RollingFileAppender 扩展了FileAppender,具有滚动更新日志文件的功能,其包含以下几个属性: file——略 append——略 encoder——略 rollingPolicy—— 此选项是在发生滚动时指定RollingFileAppender行为的组件,包含SizeAndTimeBasedRollingPolicy、FixedWindowRollingPolicy、TimeBasedRollingPolicy。在上述配置中我们使用的是最为广泛的TimeBasedRollingPolicy。 triggeringPolicy—— 此选项是通知RollingFileAppender何时激活滚动更新过程的组件 prudent——布尔值,当为true时,不支持FixedWindowRollingPolicy。

5 Logback使用过程中遇到的问题

起初,在配置完logback.xml文件后,始终无法将日志输出到指定目录。 第一步,调试确认使用的是logback组件; 第二步,引入logback-core、logback-classic、logback-access和slf4j-api对应的jar包,验证是否可以将日志输出到指定目录。验证后发现,仍然无法解决问题,于是将引入的jar包删除。 第三步,排除springboot中包含的log4j2相关的jar,验证后仍无法解决问题。 第四步,在网上查到可能跟配置文件的命名有关,有说logback-spring.xml加载的优先级最高,于是将文件名由logback.xml改为logback-spring.xml,但是仍然无法解决问题。官网上看到的加载顺序是: logback-test.xml> logback.groovy> logback.xml。具体可见官方文档logback.qos.ch/manual/conf… 第五步,怀疑可能没加载logback.xml文件,于是在application.properties中加入logging.config=classpath:logback.xml,启动工程时报错,错误信息是: class path resource [logback.xml] cannot be resolved to URL because it does not exist。

根据错误信息可以看到,系统中根本没有加载到logback.xml文件。 第六步,由于第五步验证系统根本没有加载到logback.xml文件,于是检查了一下pom.xml文件,发现在build时,没有引入资源文件,于是修改pom.xml文件,添加如下内容,成功将日志输出到指定目录。


<resource>
  <directory>src/main/resources</directory>
  <includes>
    <include>**/*.xml</include>
  </includes>
  <filtering>false</filtering>
</resource>

以上就是Logback的使用及如何配置的详细内容,更多关于Logback的使用和配置的资料请关注编程网其它相关文章!

--结束END--

本文标题: Logback的使用及如何配置

本文链接: https://www.lsjlt.com/news/122582.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Logback的使用及如何配置
    目录1 为什么选用Logback?2 Logback的配置3 Logback的输出格式4 Appender5 Logback使用过程中遇到的问题日志在项目开发过程的作用不言而喻,项目...
    99+
    2022-11-12
  • Springboot如何使用Logback实现日志配置
    这篇文章主要讲解了“Springboot如何使用Logback实现日志配置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Springboot如何使用Logback实现日志配置”吧!概述默认情...
    99+
    2023-07-04
  • Springboot如何使用logback实现多环境配置?
    前言 Logback是由log4j创始人设计的又一个开源日记组件,Logback 当前分成三个模块:logback-core,logback- classic和logback-ac...
    99+
    2022-11-12
  • logBack配置日志文件及编码配置的示例分析
    这篇文章主要介绍了logBack配置日志文件及编码配置的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。logback输出到文件文件大小设置问题目前网上能搜到的关于输出...
    99+
    2023-06-20
  • 关于logBack配置日志文件及编码配置的问题
    记录下使用logback中遇到的问题,方便以后查看 logback输出到文件文件大小设置问题 目前网上能搜到的关于输出到日志文件的大小设置有如下两种: 1.单独的triggering...
    99+
    2022-11-12
  • springboot如何使用logback-spring配置日志格式,并分环境配置
    配置不生效的解决办法 注意:如果配置不生效,则说明spring优先加载了其他配置: 解决办法: 添加启动参数 -Dlogging.config=classpath:logb...
    99+
    2022-11-12
  • 使用springboot logback动态获取application的配置项
    目录springboot logback动态获取application的配置项logback自身支持以下方式配置因此只能使用spring提供的标签来对此参数进行配置springboo...
    99+
    2022-11-12
  • SpringBoot项目读取外置logback配置文件的问题及解决
    目录SpringBoot读取外置logback配置文件问题解决SpringBoot Logback的使用标签定义SpringBoot读取外置logback配置文件 springboo...
    99+
    2022-11-13
  • 如何使用Logback设置property参数
    这篇文章主要讲解了“如何使用Logback设置property参数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用Logback设置property参数”吧!Logback设置prop...
    99+
    2023-07-05
  • 在Spring Boot中使用slf4j与logback如何实现配置日志
    这期内容当中小编将会给大家带来有关在Spring Boot中使用slf4j与logback如何实现配置日志,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。spring boot主要的目的是:为 Spring...
    99+
    2023-05-31
    springboot slf4j logback
  • springboot怎么使用logback-spring配置日志格式,并分环境配置
    这篇文章主要介绍了springboot怎么使用logback-spring配置日志格式,并分环境配置,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。配置不生效的解决办法注意:如...
    99+
    2023-06-20
  • logback配置中变量和include的应用方式
    目录logback配置中变量和include的应用Example:首先把配置内容抽取一个公共文件default.xml然后基于公共文件定义各自的配置最后在logback.xml中就可...
    99+
    2022-11-12
  • JavaScript webpack5如何配置及使用
    这篇文章主要讲解了“JavaScript webpack5如何配置及使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript&nbs...
    99+
    2022-10-19
  • Springboot使用Logback实现日志配置与异常记录
    目录概述logback配置详解logback配置异常情况概述 默认情况下,SpringBoot内部使用logback作为系统日志实现的框架,将日志输出到控制台,不会写到日志文件。如果...
    99+
    2022-11-21
    Springboot Logback 日志配置 Springboot Logback异常记录 Springboot Logback
  • springboot logback如何从apollo配置中心读取变量
    目录springbootlogback从apollo配置中心读取变量1、在apollo配置中心添加2、项目的application.yml配置文件配置如下3、在logback.xml...
    99+
    2022-11-12
  • SpringCloud:Feign的使用及配置
    目录 Feign的使用及配置 1、Feign替代RestTemplate 2、使用Fegin步骤 3、自定义配置 4、Feign使用优化 5、Feign的最佳实践方式 Feign的使用及配置 1、Feign替代RestTemplate...
    99+
    2023-09-18
    spring cloud java spring boot
  • linux如何安装配置及使用redis
    这篇文章主要为大家展示了“linux如何安装配置及使用redis”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“linux如何安装配置及使用redis”这篇文章吧...
    99+
    2022-10-18
  • Logback如何在Springboot中使用
    Logback如何在Springboot中使用?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、导入依赖普通项目<dependency>  &n...
    99+
    2023-06-15
  • 如何使用PyCharm及常用配置详解
    目录一、Python 的 IDE —— PyCharm1.1 集成开发环境(IDE)1.2 PyCharm 介绍二、PyCharm上手使用2.1 创建Python项目2.2 新建Py...
    99+
    2022-11-12
  • .eslintrc配置目录及配置项的使用方式
    目录.eslintrc文件配置介绍规则文档eslint问题如下还有相关的案例说明今天在运行antd-design-vue的源代码项目时,发现vscode有很多eslint的报错,原因...
    99+
    2022-11-13
    eslintrc配置目录 eslintrc配置项 eslintrc配置
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作