一、理解
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