• Logback的使用


    Logback是由log4j创始人设计的另一个开源日志组件,性能比log4j要好。

    官方网站:https://logback.qos.ch/index.html

    Logback主要分为三个模块:

    • logback-core:其它两个模块的基础模块
    • logback-classic:它是log4j的一个改良版本,同时它完整实现了slf4j API
    • logback-access:访问模块与Servlet容器集成提供通过Http来访问日志的功能

            后续的日志代码都是通过SLF4J日志门面搭建日志系统,所以在代码是没有区别,主要是通过修改配置文件和pom.xml依赖

    1、logback入门

    • 添加依赖
      1. <dependency>
      2. <groupId>org.slf4jgroupId>
      3. <artifactId>slf4j-apiartifactId>
      4. <version>1.7.25version>
      5. dependency>
      6. <dependency>
      7. <groupId>ch.qos.logbackgroupId>
      8. <artifactId>logback-classicartifactId>
      9. <version>1.2.3version>
      10. dependency>
    • java代码
      1. public class logbackTest {
      2. public static final Logger LOGGER = LoggerFactory.getLogger(logbackTest.class);
      3. // 快速入门
      4. @Test
      5. public void testLogback() throws Exception {
      6. for (int i = 0; i < 10000; i++) {
      7. // 日志输出
      8. LOGGER.error("error");
      9. LOGGER.warn("warn");
      10. LOGGER.info("info");
      11. LOGGER.debug("debug");
      12. LOGGER.trace("trace");
      13. }
      14. }
      15. }

     

    2、logback配置

    logback会依次读取以下类型配置文件:

    • logback.groovy
    • logback-test.xml
    • logback.xml 如果均不存在会采用默认配置

    logback组件之间的关系

    • Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也可以定义日志类型、级别。
    • Appender:用于指定日志输出的目的地,目的地可以是控制台、文件、数据库等等。
    • Layout:负责把事件转换成字符串,格式化的日志信息的输出。在logback中Layout对象被封装在encoder中。

    基本配置信息

    1. <configuration>
    2. <property name="pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} %c [%thread]%-5level %msg%n"/>
    3. <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
    4. <target>System.errtarget>
    5. <encoder
    6. class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
    7. <pattern>${pattern}pattern>
    8. encoder>
    9. appender>
    10. <root level="ALL">
    11. <appender-ref ref="console"/>
    12. root>
    13. configuration>

    FileAppender、RollingFileAppender、Filter和异步日志配置汇总

    1. <configuration>
    2. <property name="pattern" value="[%-5level] %d{yyyy-MM-dd HH:mm:ss} %c %M %L [%thread] %m %n"/>
    3. <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
    4. <target>System.errtarget>
    5. <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
    6. <pattern>${pattern}pattern>
    7. encoder>
    8. appender>
    9. <property name="log_dir" value="logs" />
    10. <appender name="file" class="ch.qos.logback.core.FileAppender">
    11. <file>
    12. ${log_dir}/logback.log
    13. file>
    14. <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
    15. <pattern>${pattern}pattern>
    16. encoder>
    17. appender>
    18. <appender name="html" class="ch.qos.logback.core.FileAppender">
    19. <file>
    20. ${log_dir}/logback.html
    21. file>
    22. <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
    23. <layout class="ch.qos.logback.classic.html.HTMLLayout">
    24. <pattern>%-5level%d{yyyy-MM-dd HH:mm:ss}%c%M%L%thread%m%npattern>
    25. layout>
    26. encoder>
    27. appender>
    28. <appender name="rollFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
    29. <file>
    30. ${log_dir}/roll_logback.log
    31. file>
    32. <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
    33. <pattern>${pattern}pattern>
    34. encoder>
    35. <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
    36. <fileNamePattern>
    37. ${log_dir}/rolling.%d{yyyy-MM-dd-HH-mm-ss}.log%i.gz
    38. fileNamePattern>
    39. <maxFileSize>1MBmaxFileSize>
    40. rollingPolicy>
    41. <filter class="ch.qos.logback.classic.filter.LevelFilter">
    42. <level>ERRORlevel>
    43. <onMatch>ACCEPTonMatch>
    44. <onMissMatch>DENYonMissMatch>
    45. filter>
    46. appender>
    47. <appender name="async" class="ch.qos.logback.classic.AsyncAppender">
    48. <appender-ref ref="rollFile"/>
    49. appender>
    50. <root level="all">
    51. <appender-ref ref="console"/>
    52. <appender-ref ref="async"/>
    53. root>
    54. <logger name="com.itheima" level="info" additivity="false">
    55. <appender-ref ref="console"/>
    56. logger>
    57. configuration>

    :这里面定义了几种输出方式,可根据自生喜爱挑选喜欢的输出方式

    官方提供的log4j.properties转换成logback.xml

    https://logback.qos.ch/translator/

    3、logback-access的使用

            logback-access模块与Servlet容器(如Tomcat和Jetty)集成,以提供HTTP访问日志功能。我们可以使用logback-access模块来替换tomcat的访问日志。

    • 将logback-access.jar与logback-core.jar复制到$TOMCAT_HOME/lib/目录下
    • 修改$TOMCAT_HOME/conf/server.xml中的Host元素中添加:
      <Valve className="ch.qos.logback.access.tomcat.LogbackValve" />
    • logback默认会在$TOMCAT_HOME/conf下查找文件 logback-access.xml 
    1. <configuration>
    2. <statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener"/>
    3. <property name="LOG_DIR" value="${catalina.base}/logs"/>
    4. <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    5. <file>${LOG_DIR}/access.logfile>
    6. <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
    7. <fileNamePattern>access.%d{yyyy-MM-dd}.log.zipfileNamePattern>
    8. rollingPolicy>
    9. <encoder>
    10. <pattern>combinedpattern>
    11. encoder>
    12. appender>
    13. <appender-ref ref="FILE"/>
    14. configuration>

    官方配置https://logback.qos.ch/access.html#configuration

  • 相关阅读:
    Python内置数据类型
    合宙Air724UG LuatOS-Air LVGL API控件-页面 (Page)
    网络运维与网络安全 学习笔记2023.11.20
    懒羊羊闲话2
    Java电子招投标采购系统源码-适合于招标代理、政府采购、企业采购、等业务的企业
    【Docker镜像】Node.js项目之使用Dockerfile构建镜像
    前端技能树,面试复习第 49 天—— 虚拟 DOM | 虚拟 DOM 比真实 DOM 真的快吗 | Diff 算法原理
    Prometheus 监测 RocketMQ 最佳实践
    js检测数据类型总结
    西门子6ES72881ST200AA1
  • 原文地址:https://blog.csdn.net/weixin_52851967/article/details/126073537