麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > Java > 正文

淺談Java slf4j日志簡單理解

2024-07-14 08:41:30
字體:
來源:轉載
供稿:網(wǎng)友

一、理解

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

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

1. 日志門面(Facade)

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

2. slf4j連接具體的日志

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

logback是log4j的改良版,且內(nèi)部直接使用了slf4j的api,所以不用橋接器。(logback和slf4j據(jù)說是出自同一個作者)
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個優(yōu)先級從高到低依次為:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、 ALL。  如果設置優(yōu)先級為WARN,那么OFF、FATAL、ERROR、WARN 4個級別的log能正常輸出  設置為OFF 表示不記錄log4j2本身的日志, --><!-- status:用來指定log4j本身的打印日志級別,monitorInterval:指定log4j自動重新配置的監(jiān)測間隔時間 --><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. 輸出到滾動保存的文件, 觸發(fā)保存日志文件的條件是日志文件大于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. 輸出到滾動保存的文件, 觸發(fā)保存日志文件的條件是日志文件大于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 中的參數(shù)max,可以限制 SizeBasedTriggeringPolicy中size超出后,只保留max個存檔-->      <DefaultRolloverStrategy max="10"/>    </RollingFile>    <!--Appender 4. 輸出到滾動保存的文件, 觸發(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 默認加載-->  <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");  }}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 国内精品久久久久久久影视红豆 | 农村寡妇偷毛片一级 | 久色视频 | 久久国产精品影视 | 亚洲国产馆| av电影网在线观看 | 亚洲成人免费电影 | 动漫孕妇被羞羞视频 | 久久久日韩精品一区二区三区 | 久久精品国产99国产精品澳门 | 国产999视频在线观看 | 黄色一级片毛片 | 国产日产精品一区四区介绍 | 美女黄页网站免费进入 | 日韩欧美高清一区 | 久久久精品网 | 日本一级黄色毛片 | 国产精品av久久久久久久久久 | 亚洲一区成人在线 | 免费看综艺策驰影院 | 56av国产精品久久久久久久 | 精品国产一区二区三区久久久蜜月 | 欧美a v在线| 国产精品剧情一区二区三区 | www国产成人免费观看视频 | 国产精品av久久久久久久久久 | 国产精品久久久久国产精品三级 | 国产91影院 | 国产二区三区视频 | 国产精品久久久久久久久久了 | av中文在线观看 | 精品黑人一区二区三区国语馆 | 欧美成人性生活片 | 羞羞视频免费视频欧美 | 激情综合在线观看 | 国产精品自在线拍 | 亚洲午夜视频在线 | 欧美一级三级在线观看 | 久久91精品 | 午夜视频在线看 | 蜜桃网在线观看 |