Java中log4j的使用

前言html

  距離上一篇文章又過去好長時間了,這段時間一直忙於工做,已經從net完全轉向Java了。工做也慢慢的步入正軌了,本身獨自完成了一個小項目,不過工做中遇到了一些問題,仍是獲得了同窗和同事的幫助。原本想從頭一點點的學習,但是時間不容許,只能邊工做邊學習,這樣學以至用,工做中遇到了問題,而後再去查資料學習,這樣學起來比較快一些。若是是剛畢業的時候,可能有時間有精力容許去從零開始學習,但是如今狀況不容許這樣,只能選擇最快的方式學習,可是Java和net都是面向對象開發,思想都是同樣的,語法上也是大同小異,由於曾經在業界流傳,c#就是微軟學習Java進行開發的一套語言。在Java開發中難免會使用日誌的記錄,最經常使用的就是log4j,一個很好的記錄日誌的方式,不久能夠打印在console上,也能夠輸出到文件中,還能夠存入數據庫,操做起來很簡單方便。我剛開始處理這一塊的時候,不懂怎麼記錄系統異常,就想到了使用spring中的切面,而後在讀取log4j.properties文件存入數據庫,折騰了好幾天,後來本身又問一下同事,本身想的太多了,徹底錯了。log4j能夠把日誌直接存入數據庫的,就是簡單的幾行代碼,沒有必要那麼麻煩的,本身繞了一大圈又回來了,剛開始接觸,第一次情有可原,下不爲例了。所以本身就私下查資料學習了一下,此次完全記住了,最後整理了一下,跟你們分享一下了。java

  

具體用法:下載log4j.jar包,添加到項目中,而後建立log4j.properties文件,在文件中進行配置。node

Log4j的詳細配置說明:mysql

1、log4j.properties 的使用詳解

    1.輸出級別的種類web

        ERROR、WARN、INFO、DEBUGspring

        ERROR 爲嚴重錯誤 主要是程序的錯誤sql

        WARN 爲通常警告,好比session丟失數據庫

        INFO 爲通常要顯示的信息,好比登陸登出apache

        DEBUG 爲程序的調試信息c#

    2.配置日誌信息輸出目的地

        log4j.appender.appenderName = fully.qualified.name.of.appender.class

        (1)org.apache.log4j.ConsoleAppender(控制檯)

        (2)org.apache.log4j.FileAppender(文件)

        (3)org.apache.log4j.DailyRollingFileAppender(天天產生一個日誌文件)

        (4)org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件)

        (5)org.apache.log4j.WriterAppender(將日誌信息以流格式發送到任意指定的地方)

    3.配置日誌信息的格式

        log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class

      (1)org.apache.log4j.HTMLLayout(以HTML表格形式佈局),

       (2)org.apache.log4j.PatternLayout(能夠靈活地指定佈局模式),

      (3)org.apache.log4j.SimpleLayout(包含日誌信息的級別和信息字符串),

      (4)org.apache.log4j.TTCCLayout(包含日誌產生的時間、線程、類別等等信息)

    4.控制檯選項

        Threshold=DEBUG:指定日誌消息的輸出最低層次。

        ImmediateFlush=true:默認值是true,意謂着全部的消息都會被當即輸出。

        Target=System.err:默認狀況下是:System.out,指定輸出控制檯

        FileAppender 選項

        Threshold=DEBUF:指定日誌消息的輸出最低層次。

        ImmediateFlush=true:默認值是true,意謂着全部的消息都會被當即輸出。

        File=mylog.txt:指定消息輸出到mylog.txt文件。

        Append=false:默認值是true,即將消息增長到指定文件中,false指將消息覆蓋指定的文件內容。

        RollingFileAppender 選項

        Threshold=DEBUG:指定日誌消息的輸出最低層次。

        ImmediateFlush=true:默認值是true,意謂着全部的消息都會被當即輸出。

        File=mylog.txt:指定消息輸出到mylog.txt文件。

        Append=false:默認值是true,即將消息增長到指定文件中,false指將消息覆蓋指定的文件內容。

        MaxFileSize=100KB: 後綴能夠是KB, MB 或者是 GB. 在日誌文件到達該大小時,將會自動滾動,即將原來的內容移到mylog.log.1文件。

        MaxBackupIndex=2:指定能夠產生的滾動文件的最大數。

        log4j.appender.A1.layout.ConversionPattern=%-4r %-5p %d{yyyy-MM-dd HH:mm:ssS} %c %m%n

    5.日誌信息格式中幾個符號所表明的含義:

         -X號: X信息輸出時左對齊;

         %p: 輸出日誌信息優先級,即DEBUG,INFO,WARN,ERROR,FATAL,

         %d: 輸出日誌時間點的日期或時間,默認格式爲ISO8601,也能夠在其後指定格式,好比:%d{yyy MMM dd HH:mm:ss,SSS},輸出相似:2002年10月18日 22:10:28,921

         %r: 輸出自應用啓動到輸出該log信息耗費的毫秒數

         %c: 輸出日誌信息所屬的類目,一般就是所在類的全名

         %t: 輸出產生該日誌事件的線程名

         %l: 輸出日誌事件的發生位置,至關於%C.%M(%F:%L)的組合,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main (TestLog4.java:10)

         %x: 輸出和當前線程相關聯的NDC(嵌套診斷環境),尤爲用到像java servlets這樣的多客戶多線程的應用中。

         %%: 輸出一個"%"字符

         %F: 輸出日誌消息產生時所在的文件名稱

         %L: 輸出代碼中的行號

         %m: 輸出代碼中指定的消息,產生的日誌具體信息

         %n: 輸出一個回車換行符,Windows平臺爲"/r/n",Unix平臺爲"/n"輸出日誌信息換行    

    能夠在%與模式字符之間加上修飾符來控制其最小寬度、最大寬度、和文本的對齊方式。如:

       1)   %20c:指定輸出category的名稱,最小的寬度是20,若是category的名稱小於20的話,默認的狀況下右對齊。

       2)   %-20c:指定輸出category的名稱,最小的寬度是20,若是category的名稱小於20的話,"-"號指定左對齊。

       3)   %.30c:指定輸出category的名稱,最大的寬度是30,若是category的名稱大於30的話,就會將左邊多出的字符截掉,但小於30的話也不會有空格。

       4)   %20.30c:若是category的名稱小於20就補空格,而且右對齊,若是其名稱長於30字符,就從左邊較遠輸出的字符截掉。

 

Log4J採用相似C語言中的printf函數的打印格式格式化日誌信息,打印參數以下:

# %m 輸出代碼中指定的消息

# %p 輸出優先級,即DEBUG,INFO,WARN,ERROR,FATAL

# %r 輸出自應用啓動到輸出該log信息耗費的毫秒數

# %c 輸出所屬的類目,一般就是所在類的全名

# %t 輸出產生該日誌事件的線程名

# %n 輸出一個回車換行符,Windows平臺爲「\r\n」,Unix平臺爲「\n」

# %d 輸出日誌時間點的日期或時間,默認格式爲ISO8601,也能夠在其後指定格式

#    如:%d{yyyyMM月dd HH:mm:ss,SSS},輸出相似:2012年01月05日 22:10:28,921

# %l 輸出日誌事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數

#    如:Testlog.main(TestLog.java:10)

# %F 輸出日誌消息產生時所在的文件名稱

# %L 輸出代碼中的行號

# %x 輸出和當前線程相關聯的NDC(嵌套診斷環境),像java servlets多客戶多線程的應用中

# %% 輸出一個"%"字符

#

# 能夠在%與模式字符之間加上修飾符來控制其最小寬度、最大寬度、和文本的對齊方式。如:

#  %5c: 輸出category名稱,最小寬度是5,category<5,默認的狀況下右對齊

#  %-5c:輸出category名稱,最小寬度是5,category<5,"-"號指定左對齊,會有空格

#  %.5c:輸出category名稱,最大寬度是5,category>5,就會將左邊多出的字符截掉,<5不會有空格

#  %20.30c:category名稱<20補空格,而且右對齊,>30字符,就從左邊交遠銷出的字符截掉

2、log4j.properties的配置

    一、配置步驟

      1) 在應用程序中使用log4j

      2)  把log4j-*.*jar放入CLASSPATH變量中

      3)  新建一個配置文件log4j.properties,放於bin文件下

    二、新建一個配置文件log4j.properties,如:

      log4j.rootLogger=WARN, stdout, R

      log4j.appender.stdout=org.apache.log4j.ConsoleAppender

      log4j.appender.stdout.layout=org.apache.log4j.PatternLayout

      Pattern to output the caller's file name and line number.

      log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n

      # Print the date in ISO 8601 format

      log4j.appender.stdout.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

      log4j.appender.R=org.apache.log4j.RollingFileAppender

      log4j.appender.R.File=example.log

      log4j.appender.R.MaxFileSize=100KB

      # Keep one backup file

      log4j.appender.R.MaxBackupIndex=1

      log4j.appender.R.layout=org.apache.log4j.PatternLayout

      log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n

      # Print only messages of level WARN or above in the package com.foo.

      log4j.logger.com.foo=WARN

3編譯並運行TestLog4j會在目錄下生成一個example.log的文件,屏幕也會輸出信息,這證實已經你已經成功了第一步。

(1)配置根Logger,其語法爲:

log4j.rootLogger = [level],appenderName,appenderName2,...

level是日誌記錄的優先級,分爲OFF,TRACE,DEBUG,INFO,WARN,ERROR,FATAL,ALL

Log4j建議只使用四個級別,優先級從低到高分別是DEBUG,INFO,WARN,ERROR

經過在這裏定義的級別,您能夠控制到應用程序中相應級別的日誌信息的開關。 

好比在這裏定義了INFO級別,則應用程序中全部DEBUG級別的日誌信息將不被打印出來

appenderName就是指定日誌信息輸出到哪一個地方。可同時指定多個輸出目的。  

(2)配置日誌信息輸出目的地Appender,其語法爲: 

log4j.appender.appenderName = fully.qualified.name.of.appender.class

log4j.appender.appenderName.optionN = valueN

Log4j提供的appender有如下幾種:

1)org.apache.log4j.ConsoleAppender(輸出到控制檯)

說明

ConsoleAppender選項屬性

-Threshold = DEBUG:指定日誌消息的輸出最低層次

-ImmediateFlush = TRUE:默認值是true,全部的消息都會被當即輸出

-Target = System.err:默認值System.out,輸出到控制檯(err爲紅色,out爲黑色)

2)org.apache.log4j.FileAppender(輸出到文件)

說明

FileAppender選項屬性

-Threshold = INFO:指定日誌消息的輸出最低層次

-ImmediateFlush = TRUE:默認值是true,全部的消息都會被當即輸出

-File = C:\log4j.log:指定消息輸出到C:\log4j.log文件

-Append = FALSE:默認值true,將消息追加到指定文件中,false指將消息覆蓋指定的文件內容

-Encoding = UTF-8:能夠指定文件編碼格式  

3)org.apache.log4j.DailyRollingFileAppender(天天產生一個日誌文件)

說明

DailyRollingFileAppender選項屬性

-Threshold = WARN:指定日誌消息的輸出最低層次

-ImmediateFlush = TRUE:默認值是true,全部的消息都會被當即輸出

-File = C:\log4j.log:指定消息輸出到C:\log4j.log文件

-Append = FALSE:默認值true,將消息追加到指定文件中,false指將消息覆蓋指定的文件內容

-DatePattern='.'yyyy-ww:每週滾動一次文件,即每週產生一個新的文件。還能夠按用如下參數:

'.'yyyy-MM:每個月

'.'yyyy-ww:每週

'.'yyyy-MM-dd:天天

'.'yyyy-MM-dd-a:天天兩次

'.'yyyy-MM-dd-HH:每小時

'.'yyyy-MM-dd-HH-mm:每分鐘

-Encoding = UTF-8:能夠指定文件編碼格式

4)org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件)

說明

RollingFileAppender選項屬性

-Threshold = ERROR:指定日誌消息的輸出最低層次

-ImmediateFlush = TRUE:默認值是true,全部的消息都會被當即輸出

-File = C:/log4j.log:指定消息輸出到C:/log4j.log文件

-Append = FALSE:默認值true,將消息追加到指定文件中,false指將消息覆蓋指定的文件內容

-MaxFileSize = 100KB:後綴能夠是KB,MB,GB.在日誌文件到達該大小時,將會自動滾動.

-MaxBackupIndex = 2:指定能夠產生的滾動文件的最大數

-Encoding = UTF-8:能夠指定文件編碼格式

5)org.apache.log4j.WriterAppender(將日誌信息以流格式發送到任意指定的地方)

(3)配置日誌信息的格式(佈局),其語法爲: 

log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class

log4j.appender.appenderName.layout.optionN = valueN  

Log4j提供的layout有如下幾種:

1)org.apache.log4j.HTMLLayout(以HTML表格形式佈局)

說明

HTMLLayout選項屬性

-LocationInfo = TRUE:默認值false,輸出Java文件名稱和行號

-Title=Struts Log Message:默認值 Log4J Log Messages

2)org.apache.log4j.PatternLayout(能夠靈活地指定佈局模式)

說明

PatternLayout選項屬性

-ConversionPattern = %m%n:格式化指定的消息(參數意思下面有)

3)org.apache.log4j.SimpleLayout(包含日誌信息的級別和信息字符串)

4)org.apache.log4j.TTCCLayout(包含日誌產生的時間、線程、類別等等信息)

5)org.apache.log4j.xml.XMLLayout(以XML形式佈局)

  說明

XMLLayout選項屬性

-LocationInfo = TRUE:默認值false,輸出java文件名稱和行號

(4)指定特定包的輸出特定的級別

log4j.logger.org.springframework=DEBUG,OFF,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB,ALL

log4j.rootLogger=ALL,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB

#輸出到控制檯

log4j.appender.systemOut = org.apache.log4j.ConsoleAppender

log4j.appender.systemOut.layout = org.apache.log4j.PatternLayout

log4j.appender.systemOut.layout.ConversionPattern = [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n

log4j.appender.systemOut.Threshold = DEBUG

log4j.appender.systemOut.ImmediateFlush = TRUE

log4j.appender.systemOut.Target = System.out

#輸出到文件

log4j.appender.logFile = org.apache.log4j.FileAppender

log4j.appender.logFile.layout = org.apache.log4j.PatternLayout

log4j.appender.logFile.layout.ConversionPattern = [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n

log4j.appender.logFile.Threshold = DEBUG

log4j.appender.logFile.ImmediateFlush = TRUE

log4j.appender.logFile.Append = TRUE

log4j.appender.logFile.File = ../Struts2/WebRoot/log/File/log4j_Struts.log

log4j.appender.logFile.Encoding = UTF-8

#按DatePattern輸出到文件

log4j.appender.logDailyFile = org.apache.log4j.DailyRollingFileAppender

log4j.appender.logDailyFile.layout = org.apache.log4j.PatternLayout

log4j.appender.logDailyFile.layout.ConversionPattern = [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n

log4j.appender.logDailyFile.Threshold = DEBUG

log4j.appender.logDailyFile.ImmediateFlush = TRUE

log4j.appender.logDailyFile.Append = TRUE

log4j.appender.logDailyFile.File = ../Struts2/WebRoot/log/DailyFile/log4j_Struts

log4j.appender.logDailyFile.DatePattern = '.'yyyy-MM-dd-HH-mm'.log'

log4j.appender.logDailyFile.Encoding = UTF-8

#設定文件大小輸出到文件

log4j.appender.logRollingFile = org.apache.log4j.RollingFileAppender

log4j.appender.logRollingFile.layout = org.apache.log4j.PatternLayout

log4j.appender.logRollingFile.layout.ConversionPattern = [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n

log4j.appender.logRollingFile.Threshold = DEBUG

log4j.appender.logRollingFile.ImmediateFlush = TRUE

log4j.appender.logRollingFile.Append = TRUE

log4j.appender.logRollingFile.File= ../Struts2/WebRoot/log/RollingFile/log4j_Struts.log

log4j.appender.logRollingFile.MaxFileSize = 1MB

log4j.appender.logRollingFile.MaxBackupIndex = 10

log4j.appender.logRollingFile.Encoding = UTF-8

#用Email發送日誌

log4j.appender.logMail = org.apache.log4j.NET.SMTPAppender

log4j.appender.logMail.layout = org.apache.log4j.HTMLLayout

log4j.appender.logMail.layout.LocationInfo = TRUE

log4j.appender.logMail.layout.Title = Struts2 Mail LogFile

log4j.appender.logMail.Threshold = DEBUG

log4j.appender.logMail.SMTPDebug = FALSE

log4j.appender.logMail.SMTPHost = SMTP.163.com 

log4j.appender.logMail.From = xly3000@163.com 

log4j.appender.logMail.To = xly3000@gmail.com 

#log4j.appender.logMail.Cc = xly3000@gmail.com 

#log4j.appender.logMail.Bcc = xly3000@gmail.com 

log4j.appender.logMail.SMTPUsername = xly3000

log4j.appender.logMail.SMTPPassword = 1234567

log4j.appender.logMail.Subject = Log4j Log Messages

#log4j.appender.logMail.BufferSize = 1024

#log4j.appender.logMail.SMTPAuth = TRUE

#將日誌登陸到MySQL數據庫

log4j.appender.logDB = org.apache.log4j.jdbc.JDBCAppender

log4j.appender.logDB.layout = org.apache.log4j.PatternLayout

log4j.appender.logDB.Driver = com.mysql.jdbc.Driver

log4j.appender.logDB.URL = jdbc:mysql://127.0.0.1:3306/xly 

log4j.appender.logDB.User = root

log4j.appender.logDB.Password = 123456

log4j.appender.logDB.Sql = INSERT INTOT_log4j(project_name,create_date,level,category,file_name,thread_name,line,all_category,message)values('Struts2','%d{yyyy-MM-ddHH:mm:ss}','%p','%c','%F','%t','%L','%l','%m')

# 將日誌按照包分類輸出的配置文件      

#根針對全部的日誌包  

    log4j.rootLogger = debug , appendConsole  

#下面兩個配置是指定包的特殊處理,針對兩個指定的日誌級別,若是不指定的話則使用父日誌記錄器(rootLogger)的,指定了就覆蓋掉了父日誌記錄器的  

    #設置dao包的日誌配置  

    log4j.logger.com.xun.log4j.dao = debug, appendDao  

    #設置service包的日誌配置  

    log4j.logger.com.xun.log4j.service = info, appendService    

    #控制檯的配置  

    log4j.appender.appendConsole = org.apache.log4j.ConsoleAppender  

    Threshold:設置此appender的日誌級別,這裏會覆蓋全局的(rootLogger中)定義的日誌級別  

    log4j.appender.appendConsole.Threshold = error  

    #設置日誌輸出編碼方式爲UTF-8,若是不指定,會以當前運行操做系統的編碼方式記錄  

    log4j.appender.appendConsole.encoding = UTF-8  

    log4j.appender.appendConsole.layout = org.apache.log4j.SimpleLayout    

    #appendDao配置  

    log4j.appender.appendDao = org.apache.log4j.FileAppender  

    log4j.appender.appendDao.layout = org.apache.log4j.PatternLayout  

    log4j.appender.appendDao.layout.ConversionPattern = [%d{yyyy-MM-dd HH:mm:ss}]--[%t] [%p] -%l -%m%n%n  

    log4j.appender.appendDao.Append = false  

    log4j.appender.appendDao.File = e:/test/log4j/dao.txt   

    #appendService  

    log4j.appender.appendService = org.apache.log4j.FileAppender  

    log4j.appender.appendService.layout = org.apache.log4j.PatternLayout  

    log4j.appender.appendService.layout.ConversionPattern = [%d{yyyy-MM-dd HH:mm:ss}]--[%t] [%p] -%l -%m%n%n  

    log4j.appender.appendService.Append = false  

    log4j.appender.appendService.File = e:/test/log4j/service.txt  

 一些XML文件配置

(1)log4j.xml

log4j.xml 
    <?xml version="1.0" encoding="UTF-8"?>  
    <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">    
    <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">  
        <!--  
           * 1. 一個appender子元素定義一個日誌輸出目的地  
           * 2. 一個logger子元素定義一個日誌寫出器  
        -->  
        <!-- catalina.out -->  
        <appender name="consoleAppend" class="org.apache.log4j.ConsoleAppender" >  
            <layout class="org.apache.log4j.PatternLayout">  
                <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p][%t][%c{1}]-[%M] %m%n" />  
            </layout>  
        </appender>  
       
        <!-- error log -->  
        <appender name="errorAppend" class="org.apache.log4j.DailyRollingFileAppender">  
            <param name="File" value="${webapp.root}/logs/error/error.html" />  
            <param name="Append" value="true" />  
            <param name="DatePattern" value="yyyy-MM-dd-HH-mm'.html'"/>  
            <param name="MaxBackupIndex" value="10" />  
            <param name="MaxFileSize" value="4000000" />  
            <param name="encoding" value="utf-8"/>  
            <layout class="org.apache.log4j.HTMLLayout">  
            </layout>  
            <filter class="org.apache.log4j.varia.LevelRangeFilter">  
                <param name="LevelMin" value="ERROR" />  
                <param name="LevelMax" value="ERROR" />  
            </filter>  
        </appender>  
        <!-- biz -->  
        <appender name="bizAppend" class="org.apache.log4j.DailyRollingFileAppender">  
            <param name="File" value="${webapp.root}/logs/biz/biz.log" />  
            <param name="Append" value="true" />  
            <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />  
            <param name="MaxBackupIndex" value="10" />  
            <param name="MaxFileSize" value="4096" />  
            <param name="encoding" value="utf-8"/>  
            <layout class="org.apache.log4j.PatternLayout">  
                <param name="ConversionPattern" value="[date:%d{yyyy-MM-dd HH:mm:ss}] %m%n" />  
            </layout>  
            <filter class="com.raycloud.bizlogger.LoggerFilter">  
                <param name="LevelMin" value="40050" />  
                <param name="LevelMax" value="40050" />  
            </filter>  
        </appender>  
        <!-- 消費者消費的消息記錄 -->  
        <appender name="taskExcutorAppend" class="org.apache.log4j.DailyRollingFileAppender">  
            <param name="File" value="${webapp.root}/logs/excutor/excutor.log" />  
            <!-- 每小時1個文件 -->  
            <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />  
            <!-- 最大文件的size,單位:Kb,Mb... -->  
            <param name="MaxFileSize" value="4096" />  
            <!-- 重啓了服務器以後,是否在原有文件的後面追加?true(默認):追加;false:不追加 -->  
            <param name="Append" value="true"/>  
            <!-- 默認 MaxBackupIndex 爲 1 -->  
            <param name="MaxBackupIndex" value="10" />  
            <param name="Encoding" value="utf-8"/>  
            <layout class="org.apache.log4j.PatternLayout">  
                <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />  
            </layout>  
            <filter class="org.apache.log4j.varia.LevelRangeFilter">  
                <param name="LevelMin" value="INFO" />  
                <param name="LevelMax" value="WARN" />  
            </filter>  
        </appender>  
        <!-- ProcessHandler的日誌 -->  
        <appender name="processHandlerAppend" class="org.apache.log4j.DailyRollingFileAppender">  
            <param name="File" value="${webapp.root}/logs/process/process.log" />  
            <!-- 每小時1個文件 -->  
            <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />  
            <!-- 最大文件的size,單位:Kb,Mb... -->  
            <param name="MaxFileSize" value="4096" />  
            <!-- 重啓了服務器以後,是否在原有文件的後面追加?true(默認):追加;false:不追加 -->  
            <param name="Append" value="true"/>  
            <!-- 默認 MaxBackupIndex 爲 1 -->  
            <param name="MaxBackupIndex" value="10" />  
            <param name="Encoding" value="utf-8"/>  
            <layout class="org.apache.log4j.PatternLayout">  
                <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />  
            </layout>  
            <filter class="org.apache.log4j.varia.LevelRangeFilter">  
                <param name="LevelMin" value="INFO" />  
                <param name="LevelMax" value="WARN" />  
            </filter>  
        </appender>  
        <!-- command node js的日誌 -->  
        <appender name="nodejsAppend" class="org.apache.log4j.DailyRollingFileAppender">  
            <param name="File" value="${webapp.root}/logs/command/nodejs.log" />  
            <!-- 每小時1個文件 -->  
            <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />  
            <!-- 最大文件的size,單位:Kb,Mb... -->  
            <param name="MaxFileSize" value="4096" />  
            <!-- 重啓了服務器以後,是否在原有文件的後面追加?true(默認):追加;false:不追加 -->  
            <param name="Append" value="true"/>  
            <!-- 默認 MaxBackupIndex 爲 1 -->  
            <param name="MaxBackupIndex" value="10" />  
            <param name="Encoding" value="utf-8"/>  
            <layout class="org.apache.log4j.PatternLayout">  
                <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />  
            </layout>  
            <filter class="org.apache.log4j.varia.LevelRangeFilter">  
                <param name="LevelMin" value="INFO" />  
                <param name="LevelMax" value="WARN" />  
            </filter>  
        </appender>  
        <!-- command ffmpeg的日誌 -->  
        <appender name="ffmpegAppend" class="org.apache.log4j.DailyRollingFileAppender">  
            <param name="File" value="${webapp.root}/logs/command/ffmpeg.log" />  
            <!-- 每小時1個文件 -->  
            <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />  
            <!-- 最大文件的size,單位:Kb,Mb... -->  
            <param name="MaxFileSize" value="4096" />  
            <!-- 重啓了服務器以後,是否在原有文件的後面追加?true(默認):追加;false:不追加 -->  
            <param name="Append" value="true"/>  
            <!-- 默認 MaxBackupIndex 爲 1 -->  
            <param name="MaxBackupIndex" value="10" />  
            <param name="Encoding" value="utf-8"/>  
            <layout class="org.apache.log4j.PatternLayout">  
                <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />  
            </layout>  
            <filter class="org.apache.log4j.varia.LevelRangeFilter">  
                <param name="LevelMin" value="INFO" />  
                <param name="LevelMax" value="WARN" />  
            </filter>  
        </appender>  
       
        <!--  
            logger的做用:  
            1.[name屬性]:指定你定義Logger對象時候的name  
            2. additivity : children-logger是否使用 rootLogger的配置,  
               additivity在log4j默認爲true。這解釋了爲何有些時候,一個日誌信息在屏幕上會有屢次輸出。  
            3.還能夠指定level(輸出級別)、appender-ref(指定哪一個append)  
         -->  
        <!-- loggers -->  
        <logger name="com.raycloud.picture.task.consumer.PictureVideoTaskExcutor" additivity="true">  
            <!-- 若是1個包想對應多個 Appender 就這樣,對於每一個Appender自定義的日誌級別能夠在Appender上加上filter -->  
            <appender-ref ref="taskExcutorAppend" />  
        </logger>  
        <logger name="com.raycloud.picture.task.handle.impl.DefaultVideoProcessorHandleImpl" additivity="true">  
            <appender-ref ref="processHandlerAppend" />  
        </logger>  
        <logger name="com.raycloud.picture.service.command.NodeJsCommandInvoke" additivity="true">  
            <appender-ref ref="nodejsAppend" />  
        </logger>  
        <logger name="com.raycloud.picture.service.command.FfmpegCommandInvoke" additivity="true">  
            <appender-ref ref="ffmpegAppend" />  
        </logger>  
       
        <!--  
            root的做用(至關於全局的意思):  
            1.[priority ]:指定默認的全局輸出級別  
            2.[appender-ref ]:指定一些默認的append(沒有指出特殊包或者類,即那些沒有指定<logger>元素的append)的輸出;  
        -->  
        <root>  
            <priority value="INFO" />  
            <!-- 將 logger 中 additivity=true 的日誌或者沒有指定<logger>的append輸出到控制檯 -->  
            <appender-ref ref="consoleAppend" />  
            <!-- 將全局的 error 日誌輸出到error文件中 -->  
            <appender-ref ref="errorAppend" />  
            <appender-ref ref="bizAppend" />  
        </root>  
    </log4j:configuration>  
View Code

 (2)log4j.xml在web.xml中的配置

log4j.xml在web.xml中的配置
    <!-- log4j -->  
        <context-param>  
            <param-name>log4jConfigLocation</param-name>  
            <param-value>classpath:log4j-server.xml</param-value>  
        </context-param>  
        <context-param>  
            <param-name>log4jRefreshInterval</param-name>  
            <param-value>3000</param-value>  
        </context-param>  
        <!-- 先開啓Log4J,再去啓動spring等一些你須要的東西,有助於報錯時日誌的輸出 -->  
        <listener>            <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>  
        </listener>  

log4j操做:
   方式一:自動快速的使用Log4J缺省的環境  
   BasicConfigurator.configure();       
   方式二:讀取properties文件(自定義位置),可是注意這裏文件的加載路徑     PropertyConfigurator.configure("E:/workspace-idea/study-demo/log4j-test/src/main/resources/log4j/log4j.properties");        PropertyConfigurator.configure(HowUseLog4JDemo.class.getClassLoader().getResource("log4j/log4j.properties").getFile());  
    方式三:讀取XML文件  
DOMConfigurator.configure("xxx");
View Code

總結:時間比較緊張,寫的比較匆忙,可能表述不清楚,或者寫的不對,有錯的地方但願你們幫忙指出。好東西就要分享,一塊兒學習一塊兒進步!(*^__^*) 嘻嘻……

相關文章
相關標籤/搜索