博客
关于我
Spring Boot--日志框架的学习
阅读量:267 次
发布时间:2019-02-28

本文共 1895 字,大约阅读时间需要 6 分钟。

Spring Boot日志框架配置与使用

版本信息

  • Spring Boot: 2.1.5.RELEASE
  • Maven: 3.2.5
  • JDK: 1.8

日志框架选择

  • 日志门面(抽象层): SLF4J
  • 日志实现: Logback

Spring Boot 2.x版本通过替换原有的日志框架,统一使用 SLF4J 和 Logback 进行日志记录。这样可以避免日志框架不一致的问题,确保整个系统的日志管理更加规范。

SLF4J 的使用

导入相关包

在项目中添加以下依赖:

org.slf4j
slf4j-api
1.7.25

日志记录方法

开发时直接调用 SLF4J 的日志方法,无需改写为 Logback 的实现类。例如:

import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class HelloWorld {    public static void main(String[] args) {        Logger logger = LoggerFactory.getLogger(HelloWorld.class);        logger.info("Hello World");    }}

统一日志管理

当引入其他日志框架(如 Hibernate 的 jboss-logging)时,需要:

  • 排除原有的日志框架依赖
  • 引入 SLF4J 相关实现
  • 使用中间包替换原有框架
  • Spring Boot 日志关系

    • Spring Boot 内置的 spring-boot-starter-logging 依赖已经包含了 SLF4J 和 Logback
    • 默认日志级别为 INFO,其他级别可通过配置文件调整

    日志配置

    日志级别设置

    application.properties 中添加:

    logging.level.com.example=trace

    这样可以设置 com.example 包下所有类的日志级别为 TRACE。

    日志输出路径

    指定日志文件路径:

    logging.path=F:/spring/log

    默认生成 spring.log 文件。

    控制台输出格式

    定义日志输出格式:

    logging.pattern.console=%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] - %5p %logger{50} : %msg%n

    Logback 配置示例

    %d{yyyy-MM-dd HH:mm:ss.SSS} ---- [%thread] --- %5p %logger{50} - %msg%n
    %d{yyyy-MM-dd HH:mm:ss.SSS} ==== [%thread] ==== %5p %logger{50} - %msg%n

    换用其他日志框架

    如需使用 Log4j2 或 JDK Util Logging,需在 pom.xml 中排除 spring-boot-starter-logging 依赖,并添加相应的实现依赖:

    org.springframework.boot
    spring-boot-starter-log4j2
    2.1.1.RELEASE

    日志文件管理

    • Logback: 使用 logback-spring.xmllogback.xml 配置
    • Log4j2: 使用 log4j2-spring.xmllog4j2.xml 配置
    • JDK Util Logging: 使用 logging.properties 配置

    通过以上配置,可以实现对不同环境(如开发、生产)的日志格式化控制,同时确保日志记录的统一性和可读性。

    转载地址:http://ecdp.baihongyu.com/

    你可能感兴趣的文章
    Netpas:不一样的SD-WAN+ 保障网络通讯品质
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    Nginx + uWSGI + Flask + Vhost
    查看>>
    Nginx Location配置总结
    查看>>
    Nginx 反向代理解决跨域问题
    查看>>
    nginx 后端获取真实ip
    查看>>