溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Logback日志基礎(chǔ)實(shí)現(xiàn)自定義配置

發(fā)布時(shí)間:2020-11-03 17:22:07 來源:億速云 閱讀:148 作者:Leah 欄目:開發(fā)技術(shù)

Logback日志基礎(chǔ)實(shí)現(xiàn)自定義配置?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

Logback日志基礎(chǔ)配置

logback日志配置有很多介紹,但是有幾個(gè)非?;A(chǔ)的,容易忽略的。下面是最簡(jiǎn)單的一個(gè)配置,注意加粗的描述

<&#63;xml version="1.0" encoding="UTF-8"&#63;>
<configuration debug="true" scan="true" scanPeriod="30 seconds">

  <!--log.path定義的是局部變量,./logs指定的是相對(duì)路徑下的文件夾logs-->
  <property name="log.path" value="./logs"/>

  <appender name="ROLLING-FILE-OUT" class="ch.qos.logback.core.rolling.RollingFileAppender">

    <!--這里的文件名是不能使用正則表達(dá)式,只能是定死的名字,實(shí)現(xiàn)了很久-->
    <file>${log.path}/errorlog.log</file>

    <!-- 日志輸出格式:%d表示日期時(shí)間,%thread表示線程名,%-5level:級(jí)別從左顯示5個(gè)字符寬度
       %logger{50} 表示logger名字最長(zhǎng)50個(gè)字符,否則按照句點(diǎn)分割。 %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:當(dāng)文件大小超過maxFileSize時(shí),按照i進(jìn)行文件滾動(dòng),i從0開始滾動(dòng) -->
      <FileNamePattern>${log.pat h}/errorlog.%d{yyyyMMdd}.log.%i.gz</FileNamePattern>
      <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
        <maxFileSize>4096MB</maxFileSize>
      </timeBasedFileNamingAndTriggeringPolicy>
      <!--日志文件保留天數(shù)-->
      <maxHistory>365</maxHistory>
    </rollingPolicy>
  </appender>

  <!-- 日志級(jí)別-->
  <root level="debug">   
    <appender-ref ref="ROLLING-FILE-OUT"/>
  </root>

</configuration>

在規(guī)范里,行結(jié)束符往往采用Linux結(jié)束符(\n),而不是上面那樣的 %n。 這個(gè)\n ,使用txt文檔查看,并沒有換行

使用%的正則還有許許多多,比如如下:

<property name="CONSOLE_LOG_PATTERN" value="%date{yyyy-MM-dd HH:mm:ss} | %highlight(%-5level) | %yellow(%thread) | %green(%logger) | %msg%n"/>

再比如:%contextName 作用是 顯示主機(jī)名

Logback日志自定義配置

即便如此,還是有很多想要的東西顯示不了,這時(shí)就可自定義配置。比如我希望每條日志有個(gè)uuid類型的id,希望每條日志能打印ip地址

一、新建兩個(gè)配置類,重寫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>

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI