zoukankan      html  css  js  c++  java
  • Logback

    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依赖
     logback入门
    1. 添加依赖

     <dependencies>
            <!--slf4j 日志门面-->
            <!--    <dependency>
                   <groupId>org.slf4j</groupId>
                   <artifactId>slf4j-api</artifactId>
                   <version>1.7.26</version>
               </dependency>-->
            <!--logback 日志实现-->
            <dependency>
                <groupId>ch.qos.logback</groupId>
                <artifactId>logback-classic</artifactId>
                <version>1.2.3</version>
            </dependency>
            <!--junti 单元测试-->
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.12</version>
            </dependency>
        </dependencies>
    public class LogbackTest {
    
        public static final Logger LOGGER = LoggerFactory.getLogger(LogbackTest.class);
    
    
        // 快速入门
        @Test
        public void testQuick()throws Exception{
    
    
            //for (int i = 0; i < 10000; i++) {
    
                // 日志输出
                LOGGER.error("error");
                LOGGER.warn("wring");
                LOGGER.info("info");
                LOGGER.debug("debug");// 默认级别
                LOGGER.trace("trace");
           // }
    
        }
    }

    logback配置
    logback会依次读取以下类型配置文件:
    logback.groovy
    logback-test.xml
    logback.xml 如果均不存在会采用默认配置
    1. logback组件之间的关系
          1. Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也可以定义日志类型、级别。
          2. Appender:用于指定日志输出的目的地,目的地可以是控制台、文件、数据库等等。
          3. Layout:负责把事件转换成字符串,格式化的日志信息的输出。在logbackLayout对象被封装在encoder中。
    2. 基本配置信息 

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration>
    
        <!--
            配置集中管理属性
            我们可以直接改属性的 value 值
            格式:${name}
        -->
        <property name="pattern" value="[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} %c %M %L [%thread] %m%n"></property>
        <!--
        日志输出格式:
            %-5level
            %d{yyyy-MM-dd HH:mm:ss.SSS}日期
            %c类的完整名称
            %M为method
            %L为行号
            %thread线程名称
            %m或者%msg为信息
            %n换行
          -->
        <!--定义日志文件保存路径属性-->
        <property name="log_dir" value="/logs"></property>
    
    
        <!--控制台日志输出的 appender-->
        <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
            <!--控制输出流对象 默认 System.out 改为 System.err-->
            <target>System.err</target>
            <!--日志消息格式配置-->
            <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
                <pattern>${pattern}</pattern>
            </encoder>
        </appender>
    
        <!--日志文件输出的 appender-->
        <appender name="file" class="ch.qos.logback.core.FileAppender">
            <!--日志文件保存路径-->
            <file>${log_dir}/logback.log</file>
            <!--日志消息格式配置-->
            <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
                <pattern>${pattern}</pattern>
            </encoder>
        </appender>
    
        <!--html 格式日志文件输出 appender-->
        <appender name="htmlFile" class="ch.qos.logback.core.FileAppender">
            <!--日志文件保存路径-->
            <file>${log_dir}/logback.html</file>
            <!--html 消息格式配置-->
            <encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
                <layout class="ch.qos.logback.classic.html.HTMLLayout">
                    <pattern>%-5level%d{yyyy-MM-dd HH:mm:ss.SSS}%c%M%L%thread%m</pattern>
                </layout>
            </encoder>
        </appender>
    
    
        <!--日志拆分和归档压缩的 appender 对象-->
        <appender name="rollFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
            <!--日志文件保存路径-->
            <file>${log_dir}/roll_logback.log</file>
            <!--日志消息格式配置-->
            <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
                <pattern>${pattern}</pattern>
            </encoder>
            <!--指定拆分规则-->
            <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
                <!--按照时间和压缩格式声明拆分的文件名-->
                <fileNamePattern>${log_dir}/rolling.%d{yyyy-MM-dd}.log%i.gz</fileNamePattern>
                <!--按照文件大小拆分-->
                <maxFileSize>1MB</maxFileSize>
            </rollingPolicy>
            <!--日志级别过滤器-->
            <filter class="ch.qos.logback.classic.filter.LevelFilter">
                <!--日志过滤规则-->
                <level>ERROR</level>
                <onMatch>ACCEPT</onMatch>
                <onMismatch>DENY</onMismatch>
            </filter>
        </appender>
    
        <!--异步日志-->
        <appender name="async" class="ch.qos.logback.classic.AsyncAppender">
            <!--指定某个具体的 appender-->
            <appender-ref ref="rollFile"/>
        </appender>
    
    
        <!--root logger 配置-->
        <root level="ALL">
            <appender-ref ref="console"/>
            <appender-ref ref="async"/>
        </root>
    
        <!--自定义 looger 对象
            additivity="false" 自定义 logger 对象是否继承 rootLogger
         -->
        <logger name="com.topcheer" level="info" additivity="false">
            <appender-ref ref="console"/>
        </logger>
    </configuration>

     注:说几点刚刚自己测试的建议。

    • 当有多个拆分文件的时候,建议名字要区分开来,不然会覆盖。
    • 就是在自定义的时候,最好一般都是继承root logger,不然在总的里面无法查到它的相关日志信息。
    • 当然也可以在自定义的时候,加个过滤器只记录自己想看的一些信息。
    • 而且假如有些appender没有配置在root里面,它是会生成一个空的log文件

    3. 官方提供的log4j.properties转换成logback.xml
    https://logback.qos.ch/translator/ 

     logback-access的使用
    logback-access模块与Servlet容器(如TomcatJetty)集成,以提供HTTP访问日志功能。我们可以使
    logback-access模块来替换tomcat的访问日志。
    1. logback-access.jarlogback-core.jar复制到$TOMCAT_HOME/lib/目录下
    2. 修改$TOMCAT_HOME/conf/server.xml中的Host元素中添加:

    <Valve className="ch.qos.logback.access.tomcat.LogbackValve" />

    3. logback默认会在$TOMCAT_HOME/conf下查找文件 logback-access.xml 

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration>
      <!-- always a good activate OnConsoleStatusListener -->
      <statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener"/> 
      
      <property name="LOG_DIR" value="${catalina.base}/logs"/>
     
      <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${LOG_DIR}/access.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
          <fileNamePattern>access.%d{yyyy-MM-dd}.log.zip</fileNamePattern>
        </rollingPolicy>
     
        <encoder>
          <pattern>combined</pattern>
        </encoder>
      </appender>
      
      <appender-ref ref="FILE"/>
    </configuration>

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

  • 相关阅读:
    Mybatis-Plus select不列出全部字段
    git合并之 merge和rebase
    git
    springboot缓存开发
    关于Maven打包
    邮件发送模型及其Python应用实例
    Python 日志模块的定制
    python 解析 XML文件
    有限状态机FSM详解及其实现
    动态规划
  • 原文地址:https://www.cnblogs.com/dalianpai/p/12341494.html
Copyright © 2011-2022 走看看