亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

在Java中使用日志框架log4j的方法

 更新時間:2021年08月02日 10:23:32   作者:Step to Step_001  
Log4j有三個主要的組件/對象:Loggers(記錄器),Appenders (輸出源)和Layouts(布局)。這里可簡單理解為日志類別,日志要輸出的地方和日志以何種形式輸出,今天通過本文給大家分享Java日志框架log4j的相關(guān)知識,感興趣的朋友一起看看吧

日志就是記錄程序的運行軌跡,方便快速定位問題

如果用System.out.println(),信息是打印在控制臺。等到產(chǎn)品上線后沒有控制臺,如果有報錯信息,根本不知道去哪里看,就不知道是哪里出錯。

而且開發(fā)的時候希望打印輸出的內(nèi)容多。方便排查,上線后只希望打印容易出錯的部分。System.out.println()滿足不了這個需求

而日志框架可以讓錯誤信息輸出到多個指定文件,不同的文件有不同的輸出內(nèi)容。方便排錯,定位錯誤

一、log4j介紹

Log4j有三個主要的組件/對象:Loggers(記錄器),Appenders (輸出源)和Layouts(布局)。這里可簡單理解為日志類別,日志要輸出的地方和日志以何種形式輸出。

每條日志語句都要設(shè)置一個等級(DEBUG、INFO、WARN、ERROR和FATAL)。

其中DEBUG < INFO < WARN < ERROR < FATAL。fatal等級最高

對應(yīng)調(diào)試信息 一般信息 警告信息 錯誤信息 嚴(yán)重錯誤信息

1、Loggers

在設(shè)置日志輸出位置的時候,會給那個位置設(shè)置一個級別,只有大于等于那個級別的日志才會打印輸出到指定位置。

例如:某個Loggers(日志輸出位置的等級記錄器)級別設(shè)定為INFO,則INFO、WARN、ERROR和FATAL級別的日志信息都會輸出到那個文件,而級別比INFO低的DEBUG則不會輸出。

2、Appenders


禁用和使用日志請求只是Log4j的基本功能,Log4j日志系統(tǒng)還提供許多強大的功能,比如允許把日志輸出到不同的地方,如控制臺(Console)、文件(Files)等,可以根據(jù)天數(shù)或者文件大小產(chǎn)生新的文件,可以以流的形式發(fā)送到其它地方等等。

常使用的類如下:

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

基本上可以滿足我們的日常需求,當(dāng)然如果你的需求比較特殊,可以自己實現(xiàn)Appender輸出路徑。只需要定義一個類,實現(xiàn)Appender接口就可以了。Appender接口中定義了一系列記錄日志的方法,按照自己的規(guī)則實現(xiàn)這些方法即可

3、Layouts

用戶可以根據(jù)自己的喜好格式化自己的日志輸出,Layouts提供四種日志輸出樣式,如根據(jù)HTML樣式、自由指定樣式、包含日志級別與信息的樣式和包含日志時間、線程、類別等信息的樣式。

常使用的類如下:

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

二、使用

在實際應(yīng)用中,要使Log4j在系統(tǒng)中運行必須事先設(shè)定配置文件。配置文件事實上也就是對Logger、Appender及Layout進行相應(yīng)設(shè)定。Log4j支持兩種配置文件格式,一種是XML格式的文件,一種是properties屬性文件,配置文件詳解在下面使用部分說明

我是用maven創(chuàng)建項目

 1、導(dǎo)包

 在pom.xml

  <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>

2、創(chuàng)建配置文件

日志配置文件:log4j.properties文件或者logback.xml。

我用的是log4j.properties

在普通的se項目中放到src同級目錄下,maven項目中放到src/main/resources目錄下

### 日志的輸出級別是dubug,輸出位置名字叫stdout,D
log4j.rootLogger = debug,stdout,D
 
### 輸出信息到控制抬 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
#用特定格式輸出日志
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
#下面是規(guī)定好的格式,有點像c語言printf的%d,%m是輸出代碼中指定的消息的占位符
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
 
### 輸出warn 級別以上的日志到文件里
# 文件位置為:D:/logs/error.log4j
log4j.appender.D = org.apache.log4j.FileAppender
log4j.appender.D.File = D:/logs/error.log4j
log4j.appender.D.Append = true
log4j.appender.D.Threshold = warn 
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

3、使用

在代碼中使用Log4j

public class Test {
    @org.junit.Test
    public void testLog(){
        //1、獲取日志記錄器,這個記錄器將負責(zé)控制日志信息
        //Name一般取當(dāng)前類的名字
        Logger logger = Logger.getLogger(Test.class);
 
        //直接使用日志記錄器,打印日志
        logger.debug("dubug級別");
        logger.error("error級別");
    }
}

最后結(jié)果:

控制臺輸出

磁盤中的文件輸出

-------------------------------下面的太復(fù)雜------------------------------------

http://chabaoo.cn/article/134950.htm

http://chabaoo.cn/article/121581.htm

###配置日志根Logger
#第一參數(shù)是日志輸出級別,這里是一個全局級別,只要它指定了error,下面不管設(shè)置什么比它的低級別都會失效,所以一般指定dubug
#后面幾個參數(shù)都是日志輸出的位置,多個輸出路徑用,隔開;隨便起名只是一個代號
log4j.rootLogger=DEBUG,out1,out2,out3,out4
 
 
#ERROR 為嚴(yán)重錯誤 主要是程序的錯誤
#WARN 為一般警告,比如session丟失
#INFO 為一般要顯示的信息,比如登錄登出
#DEBUG 為程序的調(diào)試信息
 
#表示Logger的內(nèi)容不會在父Logger的appender里輸出,默認為true。
(?可能是這樣,要輸出日志時,得先創(chuàng)建一個Logger對象,用Logger對象打印,如果這里是true,日志內(nèi)容不僅會出現(xiàn)在當(dāng)前配置的日志文件里,還會出現(xiàn)在父類的日志文件里)
log4j.additivity.org.apache=false

下面的輸出位置名字分別是 out1,out2,out3,out4

###配置日志信息輸出目的地Appender,appender后面的參數(shù)對應(yīng)log4j.rootLogger的位置名稱
 
log4j.appender.out1=org.apache.log4j.ConsoleAppender #打印到控制臺
log4j.appender.out1.Threshold=DEBUG #指定日志信息的最低輸出級別,默認為DEBUG。
log4j.appender.out1.ImmediateFlush=true #表示所有消息都會被立即輸出,設(shè)為false則不輸出,默認值是true。
log4j.appender.out1.Target=System.err #默認值是System.out。?不知道是什么
log4j.appender.out1.layout=org.apache.log4j.PatternLayout #可以靈活地指定布局模式
log4j.appender.out1.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n  #布局格式
 
 
 
# 日志文件(logFile)
log4j.appender.logFile=org.apache.log4j.FileAppender
log4j.appender.logFile.Threshold=DEBUG
log4j.appender.logFile.ImmediateFlush=true
log4j.appender.logFile.Append=true
log4j.appender.logFile.File=D:/logs/log.log4j
log4j.appender.logFile.layout=org.apache.log4j.PatternLayout
log4j.appender.logFile.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n
 
 
### 輸出到日志文件 ###
#org.apache.log4j.ConsoleAppender
#org.apache.log4j.FileAppender(文件)
#org.apache.log4j.DailyRollingFileAppender
#org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產(chǎn)生一個新的文件)
#org.apache.log4j.WriterAppender(將日志信息以流格式發(fā)送到任意指定的地方)
#log4j.appender.error.Target=System.out

 logback.xml可以看:http://chabaoo.cn/article/207994.htm

使用

在不同環(huán)境使用日志框架:http://chabaoo.cn/article/74475.htm

http://chabaoo.cn/article/207994.htm

http://chabaoo.cn/article/197121.htm

到此這篇關(guān)于在Java中使用日志框架log4j的文章就介紹到這了,更多相關(guān)Java日志框架log4j內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Maven deploy配置方法詳解

    Maven deploy配置方法詳解

    這篇文章主要介紹了Maven deploy配置方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Java線程池中的工作線程Worker類源碼解析

    Java線程池中的工作線程Worker類源碼解析

    這篇文章主要介紹了Java線程池中的工作線程Worker類源碼解析,線程池中的工作線程是通過內(nèi)部類Worker表示的,Worker繼承自AbstractQueueSynchronizer,可以實現(xiàn)同步器的功能,需要的朋友可以參考下
    2023-12-12
  • Java多線程編程之CountDownLatch同步工具使用實例

    Java多線程編程之CountDownLatch同步工具使用實例

    這篇文章主要介紹了Java多線程編程之CountDownLatch同步工具使用實例,需要的朋友可以參考下
    2015-05-05
  • Java多線程高并發(fā)中的Fork/Join框架機制詳解

    Java多線程高并發(fā)中的Fork/Join框架機制詳解

    本文主要介紹了 Java 多線程高并發(fā)中的 Fork/Join 框架的基本原理和其使用的工作竊取算法(work-stealing)、設(shè)計方式和部分實現(xiàn)源碼,感興趣的朋友跟隨小編一起看看吧
    2021-11-11
  • Java 讀取文件方法大全

    Java 讀取文件方法大全

    這篇文章主要介紹了Java 讀取文件方法大全,需要的朋友可以參考下
    2014-11-11
  • Java二叉樹的四種遍歷(遞歸與非遞歸)

    Java二叉樹的四種遍歷(遞歸與非遞歸)

    這篇文章小編給大家分享的是Java二叉樹的四種遍歷,主要是遞歸與非遞歸,下面文章加u來詳細介紹,感興趣的小伙伴一起來學(xué)習(xí)吧
    2021-10-10
  • SpringBoot實現(xiàn)前后端、json數(shù)據(jù)交互以及Controller接收參數(shù)的幾種常用方式

    SpringBoot實現(xiàn)前后端、json數(shù)據(jù)交互以及Controller接收參數(shù)的幾種常用方式

    這篇文章主要給大家介紹了關(guān)于SpringBoot實現(xiàn)前后端、json數(shù)據(jù)交互以及Controller接收參數(shù)的幾種常用方式,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-03-03
  • Java之JNDI注入的實現(xiàn)

    Java之JNDI注入的實現(xiàn)

    JNDI是Java EE的重要部分,本文主要介紹了Java之JNDI注入的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • springboot jta atomikos實現(xiàn)分布式事物管理

    springboot jta atomikos實現(xiàn)分布式事物管理

    這篇文章主要介紹了springboot jta atomikos實現(xiàn)分布式事物管理,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • SpringBoot配置Clickhouse的示例代碼

    SpringBoot配置Clickhouse的示例代碼

    這篇文章主要介紹了SpringBoot配置Clickhouse的示例代碼,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考價值,需要的朋友可以參考下
    2022-02-02

最新評論