淺談Java slf4j日志簡(jiǎn)單理解
一、理解
slf4j(Simple Logging Facade for Java),表示為java提供的簡(jiǎn)單日志門(mén)面,更底層一點(diǎn)說(shuō)就是接口。通過(guò)將程序中的信息導(dǎo)入到日志系統(tǒng)并記錄,實(shí)現(xiàn)程序和日志系統(tǒng)的解耦
日志門(mén)面接口本身通常并沒(méi)有實(shí)際的日志輸出能力,它底層還是需要去調(diào)用具體的日志框架API的,也就是實(shí)際上它需要跟具體的日志框架結(jié)合使用。由于具體日志框架比較多,而且互相也大都不兼容,日志門(mén)面接口要想實(shí)現(xiàn)與任意日志框架結(jié)合可能需要對(duì)應(yīng)的橋接器,就好像JDBC與各種不同的數(shù)據(jù)庫(kù)之間的結(jié)合需要對(duì)應(yīng)的JDBC驅(qū)動(dòng)一樣。
1. 日志門(mén)面(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");
}
}
參考文章:http://www.dbjr.com.cn/article/143486.htm
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java SSM框架如何添加寫(xiě)日志功能
- IntelliJ IDEA遠(yuǎn)程Debug Linux的Java程序,找問(wèn)題不要只會(huì)看日志了(推薦)
- java項(xiàng)目打包成可執(zhí)行jar用log4j將日志寫(xiě)在jar所在目錄操作
- java啟動(dòng)jar包將日志打印到文本的簡(jiǎn)單操作
- Java日志框架之logback使用詳解
- 簡(jiǎn)單了解Java日志脫敏框架sensitive
- 別在Java代碼里亂打日志了,這才是正確的打日志姿勢(shì)
- Java日志API管理最佳實(shí)踐詳解
- Java工程如何打印程序日志過(guò)程解析
相關(guān)文章
解析SpringBoot中使用LoadTimeWeaving技術(shù)實(shí)現(xiàn)AOP功能
這篇文章主要介紹了SpringBoot中使用LoadTimeWeaving技術(shù)實(shí)現(xiàn)AOP功能,AOP面向切面編程,通過(guò)為目標(biāo)類織入切面的方式,實(shí)現(xiàn)對(duì)目標(biāo)類功能的增強(qiáng),本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
java計(jì)算代碼段執(zhí)行時(shí)間的詳細(xì)代碼
java里計(jì)算代碼段執(zhí)行時(shí)間可以有兩種方法,一種是毫秒級(jí)別的計(jì)算,另一種是更精確的納秒級(jí)別的計(jì)算,這篇文章主要介紹了java計(jì)算代碼段執(zhí)行時(shí)間,需要的朋友可以參考下2022-08-08

