博客
关于我
Logback入门教程学习笔记
阅读量:395 次
发布时间:2019-03-05

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

Logback详细配置与实践

Logback是Java社区广泛使用的日志框架,它以其高性能、灵活性和可扩展性著称。作为Log4j的替代品,Logback提供了更高效的实现、更丰富的配置选项以及更灵活的日志归档方式。本文将详细介绍Logback的核心组件、配置方法以及实际应用场景。

Logback的架构

Logback的架构由三个核心组件构成:LoggerAppenderLayout

  • Logger:负责生成日志信息的上下文,是应用程序与日志交互的主要接口。
  • Appender:日志输出的具体实现,负责将日志信息输出到指定的目标,如控制台或文件。
  • Layout:用于格式化日志信息,决定日志的显示方式。

Maven依赖配置

在Spring Boot项目中,为了使用Logback,我们需要添加以下依赖:

org.slf4j
slf4j-api
1.7.30
ch.qos.logback
logback-core
1.2.3
ch.qos.logback
logback-classic
1.2.3

基本配置与代码示例

resources/logback.xml中添加配置文件,例如以下内容:

%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n

创建一个日志示例类:

@Slf4jpublic class Example {    public static void main(String[] args) {        log.info("Example log from {}", Example.class.getSimpleName());    }}

运行后,控制台会输出以下信息:

09:59:36.226 [main] INFO com.logback.demo.Example - Example log from Example

Logger上下文

使用@Slf4j注解可以简化日志代码,相当于:

private static final Logger log = LoggerFactory.getLogger(Example.class);

Logger继承结构

Logback的Logger继承结构类似于Java的继承:

  • 所有Logger都是root logger的后代。
  • 如果Logger没有指定日志级别,会继承最近的祖先Logger的级别。
  • root logger默认级别为DEBUG。

参数化打印日志

使用占位符避免字符串拼接:

log.debug("Current count is {}", count);log.debug("Going to divide {} by {}", 42, zero);log.debug("user is {}", user);

详细配置

默认行为:如果没有找到配置文件,Logback会创建一个ConsoleAppender并关联到root logger。

Logback查找配置文件顺序
  • 检查logback-test.xmllogback.groovylogback.xml
  • 如果未找到,查找com.qos.logback.classic.spi.Configurator的实现。
  • 如果仍未找到,创建一个ConsoleAppender并关联到root logger。
  • 基本配置解释
    %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
    解决日志故障配置

    启用debug模式:

    输出日志如下:

    15:17:24,550 |-INFO in ch.qos.logback.classic.LoggerContext[default] - Could NOT find resource [logback-test.xml]...
    自动重载配置

    启用自动扫描:

    修改Loggers

    为特定Logger设置日志级别:

    Appenders

    ConsoleAppender

    用于控制台输出:

    %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
    FileAppender

    用于文件输出:

    tests.log
    true
    %-4relative [%thread] %-5level %logger{35} - %msg%n
    RollingFileAppender

    实现日志滚动:

    ${LOG_DIR}/${LOG_FILE}.log
    ${LOG_DIR}/${LOG_FILE}.%d{yyyy-MM-dd}.gz
    30
    3GB
    %-4relative [%thread] %-5level %logger{35} - %msg%n

    Layouts

    默认PatternLayout格式:

    %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n

    总结

    通过以上配置和实践,我们掌握了Logback的核心配置方法和实际应用场景。Logback为开发者提供了灵活的日志管理工具,能够满足不同应用场景的需求。

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

    你可能感兴趣的文章
    OSG学习:纹理映射(七)——聚光灯
    查看>>
    OSG学习:纹理映射(三)——立方图纹理映射
    查看>>
    OSG学习:纹理映射(二)——一维/二维/简单立方图纹理映射
    查看>>
    OSG学习:纹理映射(五)——计算纹理坐标
    查看>>
    OSG学习:纹理映射(六)——灯光
    查看>>
    OSG学习:纹理映射(四)——三维纹理映射
    查看>>
    OSI七层模型的TCP/IP模型都有哪几层和他们的对应关系?
    查看>>
    OSM数据如何下载使用(地图数据篇.11)
    查看>>
    OSPF 四种设备角色:IR、ABR、BR、ASBR
    查看>>
    SQL Server 存储过程分页。
    查看>>
    OSPF不能发现其他区域路由时,该怎么办?
    查看>>
    OSPF两个版本:OSPFv3与OSPFv2到底有啥区别?
    查看>>
    SQL Server 存储过程
    查看>>
    OSPF在大型网络中的应用:高效路由与可扩展性
    查看>>
    OSPF技术入门(第三十四课)
    查看>>
    OSPF技术连载10:OSPF 缺省路由
    查看>>
    OSPF技术连载13:OSPF Hello 间隔和 Dead 间隔
    查看>>
    OSPF技术连载14:OSPF路由器唯一标识符——Router ID
    查看>>
    OSPF技术连载16:DR和BDR选举机制,一篇文章搞定!
    查看>>
    OSPF技术连载17:优化OSPF网络性能利器——被动接口!
    查看>>