欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

slf4j使用log4j的配置參數(shù)方式

 更新時(shí)間:2021年12月27日 09:43:14   作者:yx0628  
這篇文章主要介紹了slf4j使用log4j的配置參數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

slf4j使用log4j的配置參數(shù)

slf4j,即簡(jiǎn)單日志門面(Simple Logging Facade for Java),不是具體的日志解決方案,它只服務(wù)于各種各樣的日志系統(tǒng)。

按照官方的說(shuō)法,SLF4J是一個(gè)用于日志系統(tǒng)的簡(jiǎn)單Facade,允許最終用戶在部署其應(yīng)用時(shí)使用其所希望的日志系統(tǒng)。

比如用戶可以自己選擇使用 log4j 或是 log4j2 。

slf4j 的 maven 配置如下

<dependency>
 <groupId>org.slf4j</groupId>
 <artifactId>slf4j-api</artifactId>
 <version>1.7.21</version>
</dependency>
<dependency>
 <groupId>org.slf4j</groupId>
 <artifactId>slf4j-log4j12</artifactId>
 <version>1.7.21</version>
</dependency>

關(guān)于具體的配置 log4j.properties

### 設(shè)置rootLogger ###
log4j.rootLogger = info,stdout,D,E
### 輸出信息到控制臺(tái) ###
### 控制臺(tái)輸出
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
### 默認(rèn)是system.out,如果system.err是紅色提示
log4j.appender.stdout.Target = System.out
### 布局格式,可以靈活指定
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
### 消息格式化
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
### 輸出INFO 級(jí)別以上的日志到=D://logs/error.log ###
### 以每天一個(gè)文件輸出日志
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
### 輸出文件目錄
log4j.appender.D.File = D://logs/log.log
### 消息增加到指定的文件中,false表示覆蓋指定文件內(nèi)容
log4j.appender.D.Append = true
### 輸出信息最低級(jí)別
log4j.appender.D.Threshold = INFO
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
### 輸出ERROR 級(jí)別以上的日志到=D://logs/error.log ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =D://logs/error.log
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

日志級(jí)別

主要有以下:

  • ERROR 錯(cuò)誤
  • WARN 警告
  • INFO 一般信息
  • DEBUG 調(diào)試信息

常用的輸出位置

  • ConsoleAppender 控制臺(tái)
  • FileAppender 文件
  • DailyRollingFileAppender 每天產(chǎn)生一個(gè)日志文件
  • RollingFileAppender 文件大小達(dá)到指定尺寸時(shí)產(chǎn)生一個(gè)新文件
  • WriterAppeder 將日志信息以流格式發(fā)送到指定地方

格式化輸出

  • -X號(hào): X信息輸出時(shí)左對(duì)齊;
  • %p: 輸出日志信息優(yōu)先級(jí),即DEBUG,INFO,WARN,ERROR,F(xiàn)ATAL,
  • %d: 輸出日志時(shí)間點(diǎn)的日期或時(shí)間,默認(rèn)格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},輸出類似:2002年10月18日 22:10:28,921
  • %r: 輸出自應(yīng)用啟動(dòng)到輸出該log信息耗費(fèi)的毫秒數(shù)
  • %c: 輸出日志信息所屬的類目,通常就是所在類的全名
  • %t: 輸出產(chǎn)生該日志事件的線程名
  • %l: 輸出日志事件的發(fā)生位置,相當(dāng)于%C.%M(%F:%L)的組合,包括類目名、發(fā)生的線程,以及在代碼中的行數(shù)。舉例:Testlog4.main (TestLog4.java:10)
  • %x: 輸出和當(dāng)前線程相關(guān)聯(lián)的NDC(嵌套診斷環(huán)境),尤其用到像Java servlets這樣的多客戶多線程的應(yīng)用中。
  • %%: 輸出一個(gè)”%”字符
  • %F: 輸出日志消息產(chǎn)生時(shí)所在的文件名稱
  • %L: 輸出代碼中的行號(hào)
  • %m: 輸出代碼中指定的消息,產(chǎn)生的日志具體信息

有時(shí)我們看到 %-5p 或者 %5p 意思就是輸出日志級(jí)別時(shí),左對(duì)齊或右對(duì)齊,4個(gè)字母的 INFO / WARN 要補(bǔ)一個(gè)空格,才能和 DEBUG / ERROR 對(duì)齊格式。

slf4j集成log4j小結(jié)

日志配置使用 Slf4j集成 log4j

  • 為什么使用slf4j
  • slf4j集成log4j所需jar包及maven配置
  • slf4j及l(fā)og4j配置文件
  • slf4j集成log4j示例

為什么使用slf4j

SLF4J,即簡(jiǎn)單日志門面(Simple Logging Facade for Java),不是具體的日志解決方案,它只服務(wù)于各種各樣的日志系統(tǒng)。按照官方的說(shuō)法,SLF4J是一個(gè)用于日志系統(tǒng)的簡(jiǎn)單Facade,允許最終用戶在部署其應(yīng)用時(shí)使用其所希望的日志系統(tǒng)。通過(guò)示例說(shuō)明該特性:

public class App {
    final Logger logger = LoggerFactory.getLogger(App.class);
    private void test() {
        logger.info("這是一條日志信息 - {}", "mafly");
    }
    public static void main(String[] args) {
        App app = new App();
        app.test();
        System.out.println("Hello World!");
    }
}

對(duì)于不同的日志系統(tǒng)而言只需增加slf4j依賴包

    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.22</version>
</dependency>

對(duì)于使用logback日志系統(tǒng)用戶而言 配置

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-core</artifactId>
    <version>1.1.9</version>
</dependency>
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.1.9</version>
</dependency>

同時(shí)配置logback.xml的配置文件,即可使用slf4j管理日志系統(tǒng),同時(shí)如果想要切換日志系統(tǒng),例如 想要切換到log4j,無(wú)需修改代碼,只需將上述logback dependency刪除,增加log4j的配置

  <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.21</version>
    </dependency>
    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>1.2.17</version>
    </dependency>

可以實(shí)現(xiàn)不修改代碼,更改日志系統(tǒng)的功能。

slf4j集成log4j所需jar包及maven配置

  <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>1.7.21</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.21</version>
    </dependency>
    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>1.2.17</version>
    </dependency>

所需外部支持可分為三部分:slf4j-api包 log4j包 以及slf4j-log4j12guanlainbao

slf4j及l(fā)og4j配置文件

在 src/main/resources中 new–>resource bundle —->寫(xiě)入文件名 log4j 生成log4j.properties文件

### config root logger
log4j.rootLogger=info, STDOUT

配置根logger 格式為 [level],appenderName1,appenderName2……

其中[level]共分為5級(jí),如下:

  • FATAL 0
  • ERROR 3
  • WARN 4
  • INFO 6
  • DEBUG 7

appendername是配置日志輸出的目的地

log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
log4j.appender.STDOUT.Target=System.out
log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout
log4j.appender.STDOUT.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p %c{1}:%L - %m%n

其中appender的類型有如下幾種:

org.apache.log4j.ConsoleAppender(控制臺(tái)),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天產(chǎn)生一個(gè)日志文件),
org.apache.log4j.RollingFileAppender(文件大小到達(dá)指定尺寸的時(shí)候產(chǎn)生一個(gè)新的文件),
org.apache.log4j.WriterAppender(將日志信息以流格式發(fā)送到任意指定的地方)

輸出格式layout有如下幾種

org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以靈活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的級(jí)別和信息字符串),
org.apache.log4j.TTCCLayout(包含日志產(chǎn)生的時(shí)間、線程、類別等等信息)

打印參數(shù)配置如下:

  • %m 輸出代碼中指定的消息
  • %p 輸出優(yōu)先級(jí),即DEBUG,INFO,WARN,ERROR,F(xiàn)ATAL
  • %r 輸出自應(yīng)用啟動(dòng)到輸出該log信息耗費(fèi)的毫秒數(shù)
  • %c 輸出所屬的類目,通常就是所在類的全名
  • %t 輸出產(chǎn)生該日志事件的線程名
  • %n 輸出一個(gè)回車換行符,Windows平臺(tái)為“\r\n”,Unix平臺(tái)為“\n”
  • %d 輸出日志時(shí)間點(diǎn)的日期或時(shí)間,默認(rèn)格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},輸出類似:2002年10月18日 22 : 10 : 28 , 921
  • %l 輸出日志事件的發(fā)生位置,包括類目名、發(fā)生的線程,以及在代碼中的行數(shù)。舉例:Testlog4.main(TestLog4.java: 10 )

輸出到文件中示例:

### 輸出到日志文件 ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG ## 輸出DEBUG級(jí)別以上的日志
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

slf4j集成log4j

約定大于配置,如果將log4j.properties放置在classpath中,即resources文件夾下 可自動(dòng)讀取

 private static  final Logger logger= LoggerFactory.getLogger(TestUtil.class);
    public static void main(String [] args){
     logger.info("info信息");
     logger.debug("debug信息");
    }

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java多線程詳細(xì)總結(jié)

    java多線程詳細(xì)總結(jié)

    以下小編就對(duì)java中的多線程進(jìn)行了詳細(xì)的總結(jié)分析,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2013-10-10
  • Sping中如何處理@Bean注解bean同名的問(wèn)題

    Sping中如何處理@Bean注解bean同名的問(wèn)題

    這篇文章主要介紹了Sping中如何處理@Bean注解bean同名的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 使用java springboot設(shè)計(jì)實(shí)現(xiàn)的圖書(shū)管理系統(tǒng)(建議收藏)

    使用java springboot設(shè)計(jì)實(shí)現(xiàn)的圖書(shū)管理系統(tǒng)(建議收藏)

    這篇文章主要介紹了使用java springboot設(shè)計(jì)實(shí)現(xiàn)的圖書(shū)管理系統(tǒng),包含了整個(gè)的開(kāi)發(fā)過(guò)程,以及過(guò)程中遇到的問(wèn)題和解決方法,對(duì)大家的學(xué)習(xí)和工作具有借鑒意義,建議收藏一下
    2021-08-08
  • Java設(shè)計(jì)模式模板方法模式(Template)用法解析

    Java設(shè)計(jì)模式模板方法模式(Template)用法解析

    這篇文章主要介紹了Java設(shè)計(jì)模式模板方法模式(Template)用法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • java內(nèi)部類的最詳細(xì)詳解

    java內(nèi)部類的最詳細(xì)詳解

    內(nèi)部類是指在一個(gè)外部類的內(nèi)部再定義一個(gè)類,下面這篇文章主要給大家介紹了關(guān)于java內(nèi)部類的最詳細(xì)詳解,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • String?concat(String?str)使用小結(jié)

    String?concat(String?str)使用小結(jié)

    這篇文章主要介紹了String?concat(String?str)使用小結(jié),在了解concat()之前,首先需要明確的是String的兩點(diǎn)特殊性,一是長(zhǎng)度不可變二是值不可變,本文給大家詳細(xì)講解,需要的朋友可以參考下
    2022-11-11
  • mybatis中方法返回泛型與resultType不一致的解決

    mybatis中方法返回泛型與resultType不一致的解決

    這篇文章主要介紹了mybatis中方法返回泛型與resultType不一致的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 淺談java中集合的由來(lái),以及集合和數(shù)組的區(qū)別詳解

    淺談java中集合的由來(lái),以及集合和數(shù)組的區(qū)別詳解

    下面小編就為大家?guī)?lái)一篇淺談java中集合的由來(lái),以及集合和數(shù)組的區(qū)別詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10
  • JavaWeb Struts文件上傳功能實(shí)現(xiàn)詳解

    JavaWeb Struts文件上傳功能實(shí)現(xiàn)詳解

    這篇文章主要為大家詳細(xì)介紹了JavaWeb Struts文件上傳功能實(shí)現(xiàn)過(guò)程,思路清晰,供大家參考,感興趣的小伙伴們可以參考一下
    2016-06-06
  • Spring配置文件中parent與abstract的使用

    Spring配置文件中parent與abstract的使用

    這篇文章主要介紹了Spring配置文件中parent與abstract的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07

最新評(píng)論