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),而不是上面那樣的 %n。 這個\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] \n</pattern>       
    </encoder>
    ...
</appender>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM