zoukankan      html  css  js  c++  java
  • Logback日志基础配置以及自定义配置

    Logback日志基础配置

    logback日志配置有很多介绍,但是有几个非常基础的,容易忽略的。下面是最简单的一个配置,注意加粗的描述

    <?xml version="1.0" encoding="UTF-8"?>
    <configuration debug="true" scan="true" scanPeriod="30 seconds">
    
        <!--log.path定义的是局部变量,./logs指定的是相对路径下的文件夹logs-->
        <property name="log.path" value="./logs"/>
    
        <appender name="ROLLING-FILE-OUT" class="ch.qos.logback.core.rolling.RollingFileAppender">
    
            <!--这里的文件名是不能使用正则表达式,只能是定死的名字,实现了很久-->
            <file>${log.path}/errorlog.log</file>
    
            <!-- 日志输出格式:%d表示日期时间,%thread表示线程名,%-5level:级别从左显示5个字符宽度
                 %logger{50} 表示logger名字最长50个字符,否则按照句点分割。 %msg:日志消息,%n是换行符 -->
            <encoder>
                <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
            </encoder>
    
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <!-- 每天日志归档路径以及格式,可以不使用log后缀,%i:当文件大小超过maxFileSize时,按照i进行文件滚动,i从0开始滚动 -->
                <FileNamePattern>${log.pat h}/errorlog.%d{yyyyMMdd}.log.%i.gz</FileNamePattern>
                <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                    <maxFileSize>4096MB</maxFileSize>
                </timeBasedFileNamingAndTriggeringPolicy>
                <!--日志文件保留天数-->
                <maxHistory>365</maxHistory>
            </rollingPolicy>
        </appender>
    
        <!-- 日志级别-->
        <root level="debug">   
            <appender-ref ref="ROLLING-FILE-OUT"/>
        </root>
    
    </configuration>

    在规范里,行结束符往往采用Linux结束符( ),而不是上面那样的 %n。 这个 ,使用txt文档查看,并没有换行

    使用%的正则还有许许多多,比如如下:
    <property name="CONSOLE_LOG_PATTERN" value="%date{yyyy-MM-dd HH:mm:ss} | %highlight(%-5level) | %yellow(%thread) | %green(%logger) | %msg%n"/>

    再比如:%contextName 作用是 显示主机名

    Logback日志自定义配置

    即便如此,还是有很多想要的东西显示不了,这时就可自定义配置。比如我希望每条日志有个uuid类型的id,希望每条日志能打印ip地址

    一、新建两个配置类,重写convert方法

    package cn.jiashubing.config.logback;
    
    import ch.qos.logback.classic.pattern.ClassicConverter;
    import ch.qos.logback.classic.spi.ILoggingEvent;
    import java.util.UUID;
    
    public class LogIdConfig extends ClassicConverter {
    
        @Override
        public String convert(ILoggingEvent event) {
            return UUID.randomUUID().toString().replaceAll("-", "");
        }
    }
    
    
    package cn.jiashubing.config.logback;
    
    import ch.qos.logback.classic.pattern.ClassicConverter;
    import ch.qos.logback.classic.spi.ILoggingEvent;
    import java.net.InetAddress;
    import java.net.UnknownHostException;
    
    public class IPLogConfig extends ClassicConverter {
    
        @Override
        public String convert(ILoggingEvent event) {
            try {
                return InetAddress.getLocalHost().getHostAddress();
            } catch (UnknownHostException e) {
                e.printStackTrace();
            }
            return null;
        }
    }

    二、配置日志文件 

    <property name="log.path" value="./logs"/>
    <conversionRule conversionWord="ip" converterClass="cn.jiashubing.config.logback.IPLogConfig" />
    <conversionRule conversionWord="logid" converterClass="cn.jiashubing.config.logback.LogIdConfig" />
    
    <appender name="ROLLING-FILE-OUT" class="ch.qos.logback.core.rolling.RollingFileAppender">       
        <file>${log.path}/errorlog.log</file>       
        <encoder>           
            <pattern>[loglevel=%level] [timestamp=%d{yyyy-MM-dd HH:mm:ss}] [logid=%logid] [ip=%ip] [cmd=%msg] 
    </pattern>       
        </encoder>
        ...
    </appender>
  • 相关阅读:
    Consul注销实例
    sql优化基础篇
    linux下执行java类(运行java定时器)
    ExecutorService 的理解与使用
    精度计算的方法
    内部类详解
    接口的作用
    面向对象之继承和组合浅谈
    构造器前篇
    教师编制考试数据分析
  • 原文地址:https://www.cnblogs.com/acm-bingzi/p/logback.html
Copyright © 2011-2022 走看看