iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >springboot logback日志框架怎么配置
  • 110
分享到

springboot logback日志框架怎么配置

2023-06-30 11:06:42 110人浏览 薄情痞子
摘要

本篇内容介绍了“SpringBoot logback日志框架怎么配置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!logback既可以通过a

本篇内容介绍了“SpringBoot logback日志框架怎么配置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

logback既可以通过application配置文件进行日志的配置,又可以通过logback-spring.xml进行日志的配置。通常情况下,使用全局配置文件application.yml或properties进行配置就足够了,如果您的日志输出需求特别复杂而且需求比较个性化,可以考虑使用logback-spring.xml的配置方式。

一、application配置文件实现日志配置

我们可以在applicaition.properties(yml) 文件中进行日志的配置

logging:  level:    root: info    com.zimug.boot.launch.controller: debug  file:    path: D:\logs    name: D:\logs\boot-launch.log    max-size: 10MB    max-history: 10  pattern:    console: '%red(%d{yyyy-MM-dd HH:mm:ss}) %green([%thread]) %highlight(%-5level) %boldMagenta(%logger{10}) - %cyan(%msg%n)'    file: '%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%thread] %logger : %msg%n'
  • logging.level.root=info指定整个系统的默认日志级别是info,日志级别统一化

  • logging.level.com.zimug.boot.launch.controller=debug,指定某个特定的package的日志级别是debug,日志级别个性化。优先级角度,个性配置大于统一配置。

  • logging.file.path将日志输出到指定目录,如果不指定

  • logging.file.name,日志文件的默认名称是spring.log。配置了logging.file.name之后,logging.file.path配置失效。

  • 无论何种设置,Spring Boot都会自动按天分割日志文件,也就是说每天都会自动生成一个新的log文件,而之前的会自动打成GZ压缩包。# 日志文件大小

  • 可以设置logging.file.max-size=10MB分割的每个日志的文件最大容量,超过这个size之后日志继续分隔。

  • 可以设置保留的日志时间logging.file.max-history=10,以天为单位

  • logging.pattern.file输出到文件中的日志的格式

  • logging.pattern.console控制台输出日志的格式,为了在控制台调试时候显示效果更清晰,为日志增加了颜色。red、green等等

日志格式占位符

配合这张图,看一下占位符和logging.pattern.console格式配置之间的关系

springboot logback日志框架怎么配置

  • %d{HH:mm:ss.SSS}:日志输出时间(red)

  • %thread:输出日志的进程名字,这在WEB应用以及异步任务处理中很有用 (green)

  • %-5level:日志级别,并且使用5个字符靠左对齐 (highlight高亮蓝色)

  • %logger:日志输出类的名字 (boldMagenta粗体洋红色)

  • %msg:日志消息 (cyan蓝绿色)

  • %n:平台的换行符

二、使用logback-spring.xml实现日志配置

2.1.需求

一般情况下,使用全局配置文件application.yml或properties进行配置就足够了,如果您的日志输出需求特别复杂,可以考虑使用logback-spring.xml的配置方式。

spring boot 用自带的logback打印日志,多环境打印:

  • 生产环境输出到控制台和文件,一天一个文件,保留30天.

  • 开发环境输出到控制台和打印sql(mybatis)输出,生产环境不打印这个信息

  • 测试环境只输出到控制台。不输出到文件

打印Mybatis SQL,只需要把使用到Mybatis的package的日志级别调整为DEBUG,就可以将SQL打印出来。

2.2.需求实现

因为logback是spring boot的默认日志框架,所以不需要引入Maven依赖,直接上logback-spring.xml放在resources下面

<?xml version="1.0" encoding="UTF-8"?><configuration>    <!--引入默认的一些设置-->    <include resource="org/springframework/boot/logging/logback/defaults.xml"/>    <!--web信息-->    <logger name="org.springframework.web" level="info"/>    <!--写入日志到控制台的appender,用默认的,但是要去掉charset,否则windowsTomcat下乱码-->    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">        <encoder>            <pattern>${CONSOLE_LOG_PATTERN}</pattern>        </encoder>    </appender>    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->    <property name="LOG_PATH" value="D:/logs/boot-launch"/>    <!--写入日志到文件的appender-->    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">            <!--日志文件输出的文件名,每天一个文件-->            <FileNamePattern>${LOG_PATH}.%d{yyyy-MM-dd}.log</FileNamePattern>            <!--日志文件保留天数-->            <maxHistory>30</maxHistory>        </rollingPolicy>        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>        </encoder>        <!--日志文件最大的大小-->        <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">            <MaxFileSize>10MB</MaxFileSize>        </triggeringPolicy>    </appender>    <!--异步写日志到文件-->    <appender name="asyncFileAppender" class="ch.qos.logback.classic.AsyncAppender">        <discardingThreshold>0</discardingThreshold>        <queueSize>500</queueSize>        <appender-ref ref="FILE"/>    </appender>    <!--生产环境:打印控制台和输出到文件-->    <springProfile name="prod">        <root level="info">            <appender-ref ref="CONSOLE"/>            <appender-ref ref="asyncFileAppender"/>        </root>    </springProfile>    <!--开发环境:打印控制台-->    <springProfile name="dev">        <!-- 打印sql -->        <logger name="com.zimug.boot.launch" level="DEBUG"/>        <root level="DEBUG">            <appender-ref ref="CONSOLE"/>        </root>    </springProfile>    <!--测试环境:打印控制台-->    <springProfile name="test">        <root level="info">            <appender-ref ref="CONSOLE"/>        </root>    </springProfile></configuration>

异步日志配置:

  • 异步日志queueSize 默认值256,异步日志队列的容量。

  • discardingThreshold:当异步日志队列的剩余容量小于这个阈值,会丢弃TRACE, DEBUG or INFO级别的日志。如果不希望丢弃日志(即全量保存),那可以设置为0。但是当队列占满后,非阻塞的异步日志会变成阻塞的同步日志。所以在高并发低延迟要求的系统里面针对不重要的日志可以设置discardingThreshold丢弃策略,值大于0。

2.3.测试一下

上面配置完成之后,可以使用如下代码测试一下,是否满足了2.1节中提出的需求。

import org.slf4j.Logger;import org.slf4j.LoggerFactory;@RestControllerpublic class LogTestController {    private static final Logger logger = LoggerFactory.getLogger(LogTestController.class);    @GetMapping("/testlog")    public void test(){        logger.trace("Trace 日志...");        logger.debug("Debug 日志...");        logger.info("Info 日志...");        logger.warn("Warn 日志...");        logger.error("Error 日志...");    }}

“springboot logback日志框架怎么配置”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: springboot logback日志框架怎么配置

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

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

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

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

下载Word文档
猜你喜欢
  • springboot logback日志框架怎么配置
    本篇内容介绍了“springboot logback日志框架怎么配置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!logback既可以通过a...
    99+
    2023-06-30
  • springboot]logback日志框架配置教程
    目录一、application配置文件实现日志配置日志格式占位符二、使用logback-spring.xml实现日志配置2.1.需求2.2.需求实现2.3.测试一下logback既可...
    99+
    2022-11-13
  • Springboot如何使用Logback实现日志配置
    这篇文章主要讲解了“Springboot如何使用Logback实现日志配置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Springboot如何使用Logback实现日志配置”吧!概述默认情...
    99+
    2023-07-04
  • springboot怎么使用logback-spring配置日志格式,并分环境配置
    这篇文章主要介绍了springboot怎么使用logback-spring配置日志格式,并分环境配置,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。配置不生效的解决办法注意:如...
    99+
    2023-06-20
  • springboot项目配置logback日志系统的实现
    记录springboot项目配置logback日志文件管理: logback依赖jar包 SpringBoot项目配置logback理论上需要添加logback-classic依赖j...
    99+
    2022-11-12
  • 怎么在springboot中设置默认日志框架
    今天就跟大家聊聊有关怎么在springboot中设置默认日志框架,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。环境配置:macbook; intellij idea communit...
    99+
    2023-06-14
  • Springboot使用Logback实现日志配置与异常记录
    目录概述logback配置详解logback配置异常情况概述 默认情况下,SpringBoot内部使用logback作为系统日志实现的框架,将日志输出到控制台,不会写到日志文件。如果...
    99+
    2022-11-21
    Springboot Logback 日志配置 Springboot Logback异常记录 Springboot Logback
  • springboot项目配置logback日志系统的实现示例
    这篇文章主要介绍了springboot项目配置logback日志系统的实现示例,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。记录springboot项目配置logback日志...
    99+
    2023-06-14
  • Springboot 中怎么整合logback日志管理
    Springboot 中怎么整合logback日志管理,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.spring-boot-starter\spring-boot-star...
    99+
    2023-06-19
  • SpringBoot中logback日志怎么保存到mongoDB
    本篇内容介绍了“SpringBoot中logback日志怎么保存到mongoDB”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!自定义Appe...
    99+
    2023-06-08
  • springboot如何使用logback-spring配置日志格式,并分环境配置
    配置不生效的解决办法 注意:如果配置不生效,则说明spring优先加载了其他配置: 解决办法: 添加启动参数 -Dlogging.config=classpath:logb...
    99+
    2022-11-12
  • Java接口测试中日志框架Logback该怎样使用
    这篇文章主要为大家分析了Java接口测试中日志框架Logback该怎样使用的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“Java接口测试中日志框架Logba...
    99+
    2023-06-28
  • logback日志输出格式怎么设置
    本篇内容介绍了“logback日志输出格式怎么设置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!部分标签解释withJansi: 是否配合j...
    99+
    2023-07-05
  • 深入理解 SpringBoot 日志框架:从入门到高级应用——(三)Logback 输出日志到 MySQL 数据库
    文章目录 添加依赖导入 SQL 文件配置 logback-spring.xml运行结果 Logback 是一个开源的日志框架,它支持多种日志输出方式,包括控制台输出、文件输出、邮件输出...
    99+
    2023-09-09
    数据库 mysql logback
  • zap接收gin框架默认的日志并配置日志归档示例
    目录使用zap接收gin框架默认的日志并配置日志归档gin默认的中间件基于zap的中间件在gin项目中使用zap使用zap接收gin框架默认的日志并配置日志归档 我们在基于gin框架...
    99+
    2022-11-13
  • springboot配置日志的方法是什么
    在Spring Boot中配置日志有以下几种方法:1. 使用application.properties或application.y...
    99+
    2023-08-09
    springboot
  • springboot下mybatisplus开启打印sql日志怎么配置
    本文小编为大家详细介绍“springboot下mybatisplus开启打印sql日志怎么配置”,内容详细,步骤清晰,细节处理妥当,希望这篇“springboot下mybatisplus开启打印sql日志怎么配置”文章能帮助大家解决疑惑,下...
    99+
    2023-07-05
  • zap接收gin框架默认的日志并配置日志归档的方法
    这篇“zap接收gin框架默认的日志并配置日志归档的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“zap接收gin框架默...
    99+
    2023-06-30
  • .NET日志框架Nlog怎么使用
    这篇文章主要介绍“.NET日志框架Nlog怎么使用”,在日常操作中,相信很多人在.NET日志框架Nlog怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”.NET日志框架Nlog怎么使用”的疑惑有所帮助!...
    99+
    2023-06-29
  • .Net怎么使用日志框架NLog
    这篇文章主要讲解了“.Net怎么使用日志框架NLog”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“.Net怎么使用日志框架NLog”吧!在Nuget中安装NLogNLog可以直接使用Nuge...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作