Springboot这些强大的日志功能,你使用过吗?

日志配置详解

Spring Boot使用Commons Logging记录所有内部日志,但保留底层日志实现的打开状态。为JUL日志记录、Log4J2和Logback提供了默认配置。在每种情况下,记录器都预先配置为使用控制台输出,还可以使用可选的文件输出。

创新互联-专业网站定制、快速模板网站建设、高性价比寿县网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式寿县网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖寿县地区。费用合理售后完善,10年实体公司更值得信赖。

默认情况下,如果使用 “Starters”,则使用Logback进行日志记录。还包括适当的Logback路由,以确保使用JUL日志、Commons Logging、Log4J或SLF4J的依赖库都能正常工作。

Java有很多可用的日志框架。如果上面的列表令人困惑,请不要担心。通常,您不需要更改日志依赖项,Spring Boot默认值也可以正常工作。

1.1 日志格式

Spring Boot的默认日志输出类似于以下示例:

2019-03-05 10:57:51.112  INFO 45469 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet Engine: Apache Tomcat/7.0.52
2019-03-05 10:57:51.253  INFO 45469 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2019-03-05 10:57:51.253  INFO 45469 --- [ost-startStop-1] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 1358 ms
2019-03-05 10:57:51.698  INFO 45469 --- [ost-startStop-1] o.s.b.c.e.ServletRegistrationBean        : Mapping servlet: 'dispatcherServlet' to [/]
2019-03-05 10:57:51.702  INFO 45469 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean  : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]输出以下项目:

日期和时间:毫秒精度,易于排序。

日志级别:ERROR, WARN, INFO, DEBUG, or TRACE (错误、警告、信息、调试或跟踪) 。

进程ID。

一个---分隔符,用于区分实际日志消息的开始。

线程名称:用方括号括起来(控制台输出可能会截断)。

记录器名称:这通常是源类名称(通常缩写)。

日志消息。

1.2 控制台输出

默认日志配置在写入消息时将消息回显到控制台。默认情况下,会记录错误级别error、警告级别warn和信息级别info的消息。你还可以通过使用--debug标志启动应用程序来启用“debug”模式。

$ java -jar myapp.jar --debug

你还可以在application.properties中指定debug=true。

启用debug模式时,将配置一组核心记录器(嵌入式容器、Hibernate和Spring Boot)以输出更多信息。启用debug模式不会将应用程序配置为使用debug级别记录所有消息。或者,你可以通过使用--trace标志(或application.properties中的trace=true)启动应用程序来启用“trace”模式。这样做可以为一系列核心记录器(嵌入式容器、Hibernate模式生成和整个Spring产品组合)启用跟踪日志记录。

1.3 彩色输出日志

如果终端支持ANSI,则颜色输出用于帮助可读性。可以将spring.output.ansi.enabled设置为支持的值以覆盖自动检测。

使用%clr转换字配置颜色编码。在最简单的形式中,转换器根据日志级别为输出着色,如下例所示:

%clr(%5p)

下表描述了日志级别到颜色的映射:

Level

Color

FATAL

Red

ERROR

Red

WARN

Yellow

INFO

Green

DEBUG

Green

TRACE

Green

或者,您可以通过将颜色或样式作为转换选项来指定应使用的颜色或样式。例如,要使文本变为黄色,请使用以下设置:

%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){yellow}

支持以下颜色和样式:

  • blue
  • cyan
  • faint
  • green
  • magenta
  • red
  • yellow

具体颜色的配置可以在logback.xml或logback-spring.xml中配置,也可以在application.properties中配置

logging:
  pattern:
    console: '%clr(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}}){Green} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}'

logback-spring.xml文件配置


   
       %yellow(%date{yyyy-MM-dd HH:mm:ss}) |%highlight(%-5level) |%green(%logger:%line) |%black(%msg%n)
       UTF-8
   

1.4 日志输出文件

默认情况下,Spring Boot只将日志记录到控制台,不写入日志文件。如果要在控制台输出之外写入日志文件,则需要设置logging.file.name或logging.file.path属性(例如,在application.properties中)。

下表显示了如何将logging.*属性一起使用:

logging.file.name

logging.file.path

Example

Description

(none)

(none)

仅输出到控制台

Specific file

(none)

my.log

写入指定的日志文件。名称可以是精确的位置,也可以是相对于当前目录的。

(none)

Specific directory

/var/log

将'spring.log'写入指定目录。名称可以是精确的位置,也可以是相对于当前目录的。

日志文件在达到10 MB时会旋转,并且与控制台输出一样,默认情况下会记录错误级别、警告级别和信息级别的消息。

注意:logging.file.name与logging.file.path 不能同时出现

示例:

logging:
  level:
    com.pack: info
    web: trace
  file:
    name: d:/logs/l.log

1.5 日志文件转动/交替

如果使用的是Logback,则可以使用application.properties或application.yaml文件微调日志转动/交替设置。对于所有其他日志系统,你需要自己直接配置转动/交替设置(例如,如果使用Log4J2,则可以添加log4j.xml文件)。

支持以下轮换策略属性:

Name

Description

logging.logback.rollingpolicy.file-name-pattern

用于创建日志存档的文件名模式。

logging.logback.rollingpolicy.clean-history-on-start

如果在应用程序启动时应进行日志归档清理。

logging.logback.rollingpolicy.max-file-size

归档前日志文件的最大大小。

logging.logback.rollingpolicy.total-size-cap

删除日志存档文件之前可以接受的最大大小。

logging.logback.rollingpolicy.max-history

保留日志存档的天数(默认为7)

如下:

logging:
  logback:
    rollingpolicy:
      max-file-size: 2KB

控制日志文件大小,不超过2KB,超过的自动归档(生成压缩包)

1.6 日志级别

所有受支持的日志记录系统都可以通过使用logging.level.=在Spring环境中设置记录器级别(例如,在application.properties中),其中级别是跟踪trace、调试debug、信息info、警告warn、错误error、致命fatal或关闭off之一。可以使用logging.level.root配置根日志记录器。

以下示例显示application.properties中的可能的日志记录设置:

logging:
  level:
    root: "warn"
    org.springframework.web: "debug"
    org.hibernate: "error"
    com.pack: "error"

还可以使用环境变量设置日志记录级别。例如,日志记录_LEVEL_ORG_SPRINGFRAMEWORK_WEB=DEBUG将ORG.SPRINGFRAMEWORK.WEB设置为DEBUG。

1.7 日志分组

能够将相关的记录器分组在一起通常很有用,这样就可以同时对它们进行配置。例如,你可能通常会更改所有Tomcat相关记录器的日志记录级别,但你无法轻松记住顶级软件包。为了帮助实现这一点,SpringBoot允许你在Spring环境中定义日志记录组。例如,你可以通过将“tomcat”组添加到application.properties来定义它:

logging:
  group:
    tomcat: "org.apache.catalina,org.apache.coyote,org.apache.tomcat" #这里如果配置了会报错,应该还需要配置什么吧。

通过上面的定义后,你可以使用一行更改组中所有记录器的级别:

logging:
  level:
    tomcat: "trace"

Spring Boot包括以下可开箱即用的预定义日志组:

Name

Loggers

web

org.springframework.core.codecorg.springframework.httporg.springframework.weborg.springframework.boot.actuate.endpoint.weborg.springframework.boot.web.servlet.ServletContextInitializerBeans

sql

org.springframework.jdbc.coreorg.hibernate.SQLorg.jooq.tools.LoggerListener

这两个非常有用。

1.8 自定义日志配置

可以通过在类路径上包含适当的库来激活各种日志记录系统,还可以通过在类路径的根目录中或以下Spring环境属性指定的位置提供适当的配置文件来进一步定制:logging.config。

通过使用org.springframework.Boot.logging.LoggingSystem属性,可以强制Spring引导使用特定的日志系统。该值应该是LoggingSystem实现的完全限定类名。您还可以使用none值完全禁用Spring Boot的日志记录配置。

由于日志记录是在创建ApplicationContext之前初始化的,因此无法从Spring的@Configuration文件中的@PropertySources控制日志记录。更改或完全禁用日志系统的唯一方法是通过系统属性。

根据你的日志记录系统,将加载以下文件:

日志系统

定制

Logback

logback-spring.xmllogback-spring.groovylogback.xml, or logback.groovy

Log4j2

log4j2-spring.xml or log4j2.xml

JDK (Java Util Logging)

logging.properties

如果可能,我们建议您在日志配置中使用-spring变体(例如,logback-spring.xml而不是logback.xml)。如果使用标准配置位置,Spring无法完全控制日志初始化。

为了帮助进行自定义,其他一些属性将从Spring环境传输到系统属性,如下表所述:

Spring Environment

System Property

Comments

logging.exception-conversion-word

LOG_EXCEPTION_CONVERSION_WORD

记录异常时使用的转换字。

logging.file.name

LOG_FILE

如果已定义,则在默认日志配置中使用。

logging.file.path

LOG_PATH

如果已定义,则在默认日志配置中使用。

logging.pattern.console

CONSOLE_LOG_PATTERN

要在控制台(stdout)上使用的日志模式。

logging.pattern.dateformat

LOG_DATEFORMAT_PATTERN

日志日期格式的追加器模式。

logging.charset.console

CONSOLE_LOG_CHARSET

用于控制台日志记录的字符集。

logging.pattern.file

FILE_LOG_PATTERN

要在文件中使用的日志模式(如果启用了“日志文件”)。

logging.charset.file

FILE_LOG_CHARSET

用于文件记录的字符集(如果启用了LOG_FILE)。

logging.pattern.level

LOG_LEVEL_PATTERN

呈现日志级别时要使用的格式(默认为%5p)。

PID

PID

当前进程ID(如果可能,在尚未定义为OS环境变量时发现)。

上面这些属性(System Property)我们可以在logback-spring.xml文件中直接引用,如下:


   
       [${PID}] - [${LOG_FILE}] - [${LOG_LEVEL_PATTERN}] %yellow(%date{yyyy-MM-dd HH:mm:ss}) |%highlight(%-6level) |%green(%logger:%line) |%black(%msg%n)
       UTF-8
   

配置logging.pattern.level 属性

logging:
  pattern:
    level: INFO

输出:

[13036] - [d:/logs/l.log] - [INFO] •[33m2021-09-23 14:34:02•[0;39m |•[34mINFO  •[0;39m

如果使用的是Logback,则还会传输以下属性:

Spring Environment

System Property

Comments

logging.logback.rollingpolicy.file-name-pattern

LOGBACK_ROLLINGPOLICY_FILE_NAME_PATTERN

滚动日志文件名的模式 (default ${LOG_FILE}.%d{yyyy-MM-dd}.%i.gz).

logging.logback.rollingpolicy.clean-history-on-start

`LOGBACK_ROLLINGPOLICY_CLEAN_HISTORY_ON_START

是否在启动时清理归档日志文件。

logging.logback.rollingpolicy.max-file-size

LOGBACK_ROLLINGPOLICY_MAX_FILE_SIZE

最大日志文件大小。

logging.logback.rollingpolicy.total-size-cap

LOGBACK_ROLLINGPOLICY_TOTAL_SIZE_CAP

要保留的日志备份的总大小。

logging.logback.rollingpolicy.max-history

`LOGBACK_ROLLINGPOLICY_MAX_HISTORY

要保留的最大归档日志文件数。

所有受支持的日志系统在解析其配置文件时都可以查阅系统属性。有关示例,请参阅spring-boot.jar中的默认配置:

  • Logback
  • Log4j 2
  • Java Util logging

1.9 Logback扩展

Spring Boot包括许多对Logback的扩展,这些扩展可以帮助进行高级配置。你可以在logback-spring.xml配置文件中使用这些扩展名。

因为标准logback.xml配置文件加载得太早,所以不能在其中使用扩展名。您需要使用logback-spring.xml或定义logging.config属性。

1.9.1 配置文件特定配置

标记允许你根据活动的Spring配置文件选择性地包括或排除配置部分。配置文件部分在元素中的任何位置都受支持。使用name属性指定接受配置的配置文件。标记可以包含配置文件名称(例如staging)或配置文件表达式。配置文件表达式允许表达更复杂的配置文件逻辑,例如生产 和(central | west)。有关更多详细信息,请参阅参考指南。以下列表显示了三个示例配置文件:


   




   




   

1.9.2 环境属性

标记允许你公开Spring环境中的属性,以便在Logback中使用。如果你想从Logback配置中的application.properties文件中访问值,那么这样做很有用。该标记的工作方式与Logback的标准标记类似。但是,你可以指定属性的源(来自环境),而不是指定直接值。如果需要将属性存储在本地范围以外的其他位置,可以使用scope属性。如果需要回退值(在环境中未设置属性的情况下),可以使用defaultValue属性。以下示例显示了如何公开在Logback中使用的属性:

示例:



   ${fluentHost}
  ...

配置文件配置自定义属性:

custom:
  props:
    host: 127.0.0.1

日志文件定义(logback-spring.xml):

日志文件中使用


    
        [${host}] - [${PID}] - [${LOG_FILE}] - [${LOG_LEVEL_PATTERN}] %yellow(%date{yyyy-MM-dd HH:mm:ss}) |%highlight(%-6level) |%green(%logger:%line) |%black(%msg%n)
        UTF-8
    

测试输出:

[127.0.0.1] - [23188] - [d:/logs/l.log] - [INFO] •[33m2021-09-23 14:46:46•[0;39m

网站题目:Springboot这些强大的日志功能,你使用过吗?
URL地址:http://www.mswzjz.cn/qtweb/news4/116904.html

温江区贝锐智能技术服务部_成都网站建设公司,为您提供小程序开发静态网站建站公司域名注册网站建设面包屑导航

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能