SLF4J如何集成不同日志庫

jopen 10年前發布 | 8K 次閱讀 日志處理 SLF4j

SLF4j是Apache Common Logging的代替者。

Apache Common Logging使用的是動態綁定來確定具體日志庫,在運行時從classpath中尋找可用的具體日志庫,這樣會產生很多classloader和classpath相關的問題,而且很難排查。

Apache Common Logging不同,SLF4j采用了靜態綁定來確定具體日志庫。靜態綁定就是為每一個具體的日志庫寫一個包名和類名都相同類: org.slf4j.impl.StaticLoggerBinder,這個類的功能就是調用具體的日志庫。這個類會存放在Adaptation layer或者native implementation of slf4j-api的jar包中。SLF4j的使用者只要把具體日志庫對應的Adaptation layer或者native implementation of slf4j-api的jar包放入classpath中,SLF4j便會裝載(load)對應版本的org.slf4j.impl.StaticLoggerBinder,從而調用具體的日志庫。

下圖是調用關系圖

SLF4J如何集成不同日志庫

下圖是從SLF4j官網(http://www.slf4j.org/manual.html)截取的架構圖,紅框中是我標注的每個jar包中和綁定有關的關鍵類。


SLF4J如何集成不同日志庫

來自:http://my.oschina.net/fifadxj/blog/521170

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!