内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

Java中怎么操作slf4j日志-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)Java中怎么操作slf4j日志,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

成都創(chuàng)新互聯(lián)公司專注于企業(yè)營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、河源網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5建站、商城網(wǎng)站定制開(kāi)發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為河源等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。

一、理解

slf4j(Simple Logging Facade for Java),表示為java提供的簡(jiǎn)單日志門面,更底層一點(diǎn)說(shuō)就是接口。通過(guò)將程序中的信息導(dǎo)入到日志系統(tǒng)并記錄,實(shí)現(xiàn)程序和日志系統(tǒng)的解耦

日志門面接口本身通常并沒(méi)有實(shí)際的日志輸出能力,它底層還是需要去調(diào)用具體的日志框架API的,也就是實(shí)際上它需要跟具體的日志框架結(jié)合使用。由于具體日志框架比較多,而且互相也大都不兼容,日志門面接口要想實(shí)現(xiàn)與任意日志框架結(jié)合可能需要對(duì)應(yīng)的橋接器,就好像JDBC與各種不同的數(shù)據(jù)庫(kù)之間的結(jié)合需要對(duì)應(yīng)的JDBC驅(qū)動(dòng)一樣。

1. 日志門面(Facade)

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

2. slf4j連接具體的日志

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

logback是log4j的改良版,且內(nèi)部直接使用了slf4j的api,所以不用橋接器。(logback和slf4j據(jù)說(shuō)是出自同一個(gè)作者)
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目錄下

<?xml version="1.0" encoding="UTF-8"?>
<!--
  6個(gè)優(yōu)先級(jí)從高到低依次為:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、 ALL。
  如果設(shè)置優(yōu)先級(jí)為WARN,那么OFF、FATAL、ERROR、WARN 4個(gè)級(jí)別的log能正常輸出
  設(shè)置為OFF 表示不記錄log4j2本身的日志,
 -->

<!-- status:用來(lái)指定log4j本身的打印日志級(jí)別,monitorInterval:指定log4j自動(dòng)重新配置的監(jiān)測(cè)間隔時(shí)間 -->
<configuration status="INFO" monitorInterval="30">
  <!-- 自己設(shè)置屬性,后面通過(guò)${}來(lái)訪問(wèn) -->
  <properties>
    <property name="LOG_HOME">${web:rootDir}/logs</property>
  </properties>
  <appenders>
    <!--Appender 1. 輸出到Console控制臺(tái),指定輸出格式和過(guò)濾器等級(jí)為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. 輸出到滾動(dòng)保存的文件, 觸發(fā)保存日志文件的條件是日志文件大于3KB,只保存最新的10個(gè)日志-->
    <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. 輸出到滾動(dòng)保存的文件, 觸發(fā)保存日志文件的條件是日志文件大于3KB,只保存最新的10個(gè)日志-->
    <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 中的參數(shù)max,可以限制 SizeBasedTriggeringPolicy中size超出后,只保留max個(gè)存檔-->
      <DefaultRolloverStrategy max="10"/>
    </RollingFile>

    <!--Appender 4. 輸出到滾動(dòng)保存的文件, 觸發(fā)保存日志文件的條件是每分鐘第一次的日志事件。ERROR日志是按分鐘產(chǎn)生日志 -->
    <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 默認(rèn)加載-->
  <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

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");
  }

}

關(guān)于Java中怎么操作slf4j日志就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

文章名稱:Java中怎么操作slf4j日志-創(chuàng)新互聯(lián)
標(biāo)題鏈接:http://www.rwnh.cn/article14/doshge.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站內(nèi)鏈手機(jī)網(wǎng)站建設(shè)、商城網(wǎng)站虛擬主機(jī)、自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁(yè)設(shè)計(jì)公司
昔阳县| 教育| 谢通门县| 清水县| 竹北市| 思南县| 会泽县| 清徐县| 阿鲁科尔沁旗| 洪江市| 陵川县| 普宁市| 南木林县| 原平市| 遂昌县| 普洱| 繁峙县| 远安县| 庆安县| 赣州市| 宜兴市| 玉树县| 图片| 上饶县| 扎囊县| 青浦区| 宝丰县| 余姚市| 五河县| 旬阳县| 玉环县| 泉州市| 会宁县| 桓台县| 高邑县| 婺源县| 马关县| 长乐市| 武平县| 玉龙| 英山县|