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

本文共 1902 字,大约阅读时间需要 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/

    你可能感兴趣的文章
    Netty工作笔记0006---NIO的Buffer说明
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0013---Channel应用案例4Copy图片
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0020---Selectionkey在NIO体系
    查看>>
    Vue踩坑笔记 - 关于vue静态资源引入的问题
    查看>>
    Netty工作笔记0025---SocketChannel API
    查看>>
    Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0077---handler链调用机制实例4
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>