一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Logback日志基礎及自定義配置代碼實例

Logback日志基礎及自定義配置代碼實例

2020-09-17 23:55賈樹丙 Java教程

這篇文章主要介紹了Logback日志基礎及自定義配置代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

Logback日志基礎配置

logback日志配置有很多介紹,但是有幾個非常基礎的,容易忽略的。下面是最簡單的一個配置,注意加粗的描述

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<?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方法

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
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;
  }
}

二、配置日志文件

?
1
2
3
4
5
6
7
8
9
10
11
<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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://www.cnblogs.com/acm-bingzi/p/logback.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天天久久影视色香综合网 | 美女污视频在线观看 | 亚洲视频在线观看免费视频 | 色综合伊人色综合网亚洲欧洲 | 99这里都是精品 | 亚洲AV精品无码喷水直播间 | 我与么公激情性完整视频 | 国产亚洲自愉自愉 | 欧美日韩中文字幕久久伊人 | 日韩亚洲国产激情在线观看 | 国产一区二区免费视频 | 欧美影院天天5g天天爽 | 国产综合网站 | 好女孩韩剧免费观看 | 精品性影院一区二区三区内射 | 久久青青草原 | 好男人好资源在线观看 | 精品无码久久久久久久动漫 | 免费超级乱淫播放手机版 | 性欧美sexvideo另类 | 亚洲国产精品久久精品成人网站 | 2021小妲己永久回家地址 | 超逼网| 国色天香视频资源网 | 国产成人理在线观看视频 | 91庥豆果冻天美精东蜜桃传媒 | 高h扶她文肉 | 日韩在线视频免费不卡一区 | 亚洲AV福利天堂一区二区三 | ak福利午夜在线观看 | 欧美影院一区二区三区 | 婷婷激情综合五月天 | 精品一区二区视频 | 99久久99久久免费精品蜜桃 | 黑人干我 | 激情六月丁香婷婷四房播 | 乌克兰肛交影视 | 草莓影音 | 啪啪大幂幂被c | 成人福利影院 | 国产欧美亚洲精品第一页青草 |