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

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

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

服務器之家 - 編程語言 - Java教程 - 淺談Java slf4j日志簡單理解

淺談Java slf4j日志簡單理解

2021-05-14 10:57Developer Java教程

這篇文章主要介紹了淺談Java日志簡單理解,詳細的介紹了slf4j的概念和使用,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

一、理解

slf4j(simple logging facade for java),表示為java提供的簡單日志門面,更底層一點說就是接口。通過將程序中的信息導入到日志系統并記錄,實現程序和日志系統的解耦

日志門面接口本身通常并沒有實際的日志輸出能力,它底層還是需要去調用具體的日志框架api的,也就是實際上它需要跟具體的日志框架結合使用。由于具體日志框架比較多,而且互相也大都不兼容,日志門面接口要想實現與任意日志框架結合可能需要對應的橋接器,就好像jdbc與各種不同的數據庫之間的結合需要對應的jdbc驅動一樣。

1. 日志門面(facade)

1.slf4j(推薦)
2.commons-logging

2. slf4j連接具體的日志

slf4j和其它日志框架連接的時候,中間需要一個橋接器。有的日志框架本身就使用了slf4j的api,則不需要使用橋接器.

logback是log4j的改良版,且內部直接使用了slf4j的api,所以不用橋接器。(logback和slf4j據說是出自同一個作者)
1.slf4j-api.jar > slf4j-log4j12.jar橋接器 > log4j.jar
2.slf4j-api.jar > logback-core.jar,logback-classic.jar
3.slf4j-api.jar > slf4j-simple.jar
4.slf4j-api.jar > log4j-slf4j-impl-2.8.2.jar > org.apache.logging.log4j:log4j-api:2.8.2,org.apache.logging.log4j:log4j-core:2.8.2,org.apache.logging.log4j:log4j-web:2.8.2 (推薦使用 log4j2)

二、使用 slf4j+log4j2

log4j2.xml

放在resources目錄下

?
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
<?xml version="1.0" encoding="utf-8"?>
<!--
  6個優先級從高到低依次為:off、fatal、error、warn、info、debug、trace、 all。
  如果設置優先級為warn,那么off、fatal、error、warn 4個級別的log能正常輸出
  設置為off 表示不記錄log4j2本身的日志,
 -->
 
<!-- status:用來指定log4j本身的打印日志級別,monitorinterval:指定log4j自動重新配置的監測間隔時間 -->
<configuration status="info" monitorinterval="30">
  <!-- 自己設置屬性,后面通過${}來訪問 -->
  <properties>
    <property name="log_home">${web:rootdir}/logs</property>
  </properties>
  <appenders>
    <!--appender 1. 輸出到console控制臺,指定輸出格式和過濾器等級為info -->
    <console name="console" target="system_out">
      <!--thresholdfilter指定日志消息的輸出最低層次-->
      <thresholdfilter level="all" onmatch="accept" onmismatch="deny"/>
      <patternlayout pattern="%d{hh:mm:ss.sss} %-5level %class{36} %l %m - %msg%xex%n"/>
    </console>
 
    <!--appender 2. 輸出到滾動保存的文件, 觸發保存日志文件的條件是日志文件大于3kb,只保存最新的10個日志-->
    <file name="alllog" filename="${log_home}/all.log">
      <thresholdfilter level="all" onmatch="accept" onmismatch="deny"/>
      <patternlayout charset="utf-8" pattern="%d{yyyy.mm.dd 'at' hh:mm:ss z} %-5level %class{36} %l %m - %msg%xex%n"/>
    </file>
 
 
    <!--appender 3. 輸出到滾動保存的文件, 觸發保存日志文件的條件是日志文件大于3kb,只保存最新的10個日志-->
    <rollingfile name="debuglog" filename="${log_home}/debug.log" filepattern="${log.path}/debug-%i.log">
      <thresholdfilter level="debug" onmatch="accept" onmismatch="deny"/>
      <patternlayout charset="utf-8" pattern="[%-5level][%d{yyyy-mm-dd hh:mm:ss}][%f:%l] - %m%n"/>
      <sizebasedtriggeringpolicy size="3kb"/>
      <!-- defaultrolloverstrategy 中的參數max,可以限制 sizebasedtriggeringpolicy中size超出后,只保留max個存檔-->
      <defaultrolloverstrategy max="10"/>
    </rollingfile>
 
    <!--appender 4. 輸出到滾動保存的文件, 觸發保存日志文件的條件是每分鐘第一次的日志事件。error日志是按分鐘產生日志 -->
    <rollingfile name="errorlog" filename="${log_home}/error.log"
           filepattern="${log.path}/error-%d{yyyy-mm-dd_hh-mm}.log">
      <thresholdfilter level="error" onmatch="accept" onmismatch="deny"/>
      <patternlayout charset="utf-8" pattern="[%-5level][%d{yyyy-mm-dd hh:mm:ss}][%c:%f:%l] - %m%n"/>
      <timebasedtriggeringpolicy/>
    </rollingfile>
 
    <rollingfile name="rollingfile" filename="${log_home}/rar.log"
           filepattern="${log_home}/$${date:yyyy-mm}/${file_name}-%d{mm-dd-yyyy}-%i.log.gz">
      <patternlayout charset="utf-8" pattern="%d{yyyy-mm-dd 'at' hh:mm:ss z} %-5level %class{36} %l %m - %msg%xex%n"/>
      <!--日志文件最大值 第二天壓縮-->
      <policies>
        <timebasedtriggeringpolicy/>
        <sizebasedtriggeringpolicy size="10 mb"/>
      </policies>
    </rollingfile>
 
 
  </appenders>
  <!--root 默認加載-->
  <loggers>
    <root level="info">
      <appender-ref ref="console"/>
      <!--<appender-ref ref="alllog"/>-->
      <!--<appender-ref ref="debuglog"/>-->
      <appender-ref ref="errorlog"/>
      <!--<appender-ref ref="rollingfile"/>-->
    </root>
  </loggers>
</configuration>

logtest.java

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import org.slf4j.logger;
import org.slf4j.loggerfactory;
 
public class logtest {
  public final logger logger=loggerfactory.getlogger(getclass());
 
  public static void main(string[] args) {
    log.trace("trace");
    log.debug("debug");
    log.warn("warn");
    log.info("info");
    log.error("error");
  }
 
}

參考文章:http://m.ythuaji.com.cn/article/163507.html

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

原文鏈接:https://segmentfault.com/a/1190000015568427

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 男人网站视频 | 性关系视频网站 | 日韩在线视频免费不卡一区 | 俄罗斯男男激情1069gay | 国内精品久久久久影院男同志 | 四虎影视入口 | 国内精品露脸在线视频播放 | 91免费精品国自产拍在线不卡 | 四虎国产精品免费久久麻豆 | 欧美丝袜videohd | 日本不卡在线视频高清免费 | 青青草视频国产 | 秘书小说 | 黄动漫软件车车好快的车车 | 美女扒开胸罩露出奶了无遮挡免费 | 我要看逼| 奇米777狠狠 | 91调教| 国产亚洲精品九九久在线观看 | 9久re热视频这里只有精品 | 亚洲成在人网站天堂一区二区 | 欧美成年黄网站色高清视频 | 午夜爽喷水无码成人18禁三级 | 热色综合 | 性欧美黑人巨大喷潮xxoo | 亚洲大片免费看 | 成人小视频在线观看免费 | 大奶老太| 美味情缘韩国在线观看视频 | 色色色色色色网 | 男人狂躁女人下面的视频免费 | 久久足恋网| 日韩毛片免费线上观看 | 美女下面揉出水免费视频 | 大杳蕉在线影院在线播放 | 好深快点再快点好爽视频 | 亚洲大尺码 | 99久久国产综合精品网成人影院 | 国产香蕉一区二区在线网站 | 大ji吧快给我别停受不了视频 | 给我免费的视频在线观看 |