彷徨 | log4j日誌配置文件各參數詳解

log4j 日誌提供了兩種日誌配置方式,log4j.propertes和log4j.xml

Log4j由三個重要的組件構成:日誌信息的優先級,日誌信息的輸出目的地,日誌信息的輸出格式。日誌信息的優先級從高到低有ERROR、WARN、 INFO、DEBUG,分別用來指定這條日誌信息的重要程度;日誌信息的輸出目的地指定了日誌將打印到控制檯還是文件中;而輸出格式則控制了日誌信息的顯 示內容。


log4j.propertes

##logger是進行記錄的主要類,appender是記錄的方式,layout是記錄的格式
 
#Logger - 日誌寫出器,供程序員輸出日誌信息 
#Appender - 日誌目的地,把格式化好的日誌信息輸出到指定的地方去 
#ConsoleAppender - 目的地爲控制檯的Appender 
#FileAppender - 目的地爲文件的Appender 
#RollingFileAppender - 目的地爲大小受限的文件的Appender 
#Layout - 日誌格式化器,用來把程序員的logging request格式化成字符串 
#PatternLayout - 用指定的pattern格式化logging request的Layou
 
#Log4j提供的appender有以下幾種:
#  org.apache.log4j.ConsoleAppender(控制檯),
#  org.apache.log4j.FileAppender(文件),
#  org.apache.log4j.DailyRollingFileAppender(每天產生一個日誌文件),
#  org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產生一個新的文件),
#  org.apache.log4j.WriterAppender(將日誌信息以流格式發送到任意指定的地方)
 
#Log4j提供的layout有以下幾種:
#  org.apache.log4j.HTMLLayout(以HTML表格形式佈局),
#  org.apache.log4j.PatternLayout(可以靈活地指定佈局模式),
#  org.apache.log4j.SimpleLayout(包含日誌信息的級別和信息字符串),
#  org.apache.log4j.TTCCLayout(包含日誌產生的時間、線程、類別等等信息)
 
#Log4J採用類似C語言中的printf函數的打印格式格式化日誌信息,打印參數如下
#    %m 輸出代碼中指定的消息
#    %M 輸出日誌發生的方法名
#  %p 輸出優先級,即DEBUG,INFO,WARN,ERROR,FATAL
#  %r 輸出自應用啓動到輸出該log信息耗費的毫秒數
#  %c 輸出所屬的類目,通常就是所在類的全名
#  %t 輸出產生該日誌事件的線程名
#  %n 輸出一個回車換行符,Windows平臺爲“rn”,Unix平臺爲“n”
#  %d 輸出日誌時間點的日期或時間,默認格式爲ISO8601,也可以在其後指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},輸出類似:2002年10月18日 22:10:28,921
#  %l 輸出日誌事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數。舉例:Testlog4.main(TestLog4.java:10)
#    %L 輸出日誌發生的位置
#     %F 輸出類名
 
 
#####################################################################
#設置級別和目的地 -- 把日誌等級爲debug的日誌信息輸出到stdout和SYS,QUERY這三個目的地
log4j.rootLogger=debug,STDOUT
# stdout:目的地 -- 打印到屏幕
## org.apache.log4j.ConsoleAppender:控制檯
log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
## org.apache.log4j.PatternLayout:靈活地指定佈局模式
log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout
## 上一句設置了PatternLayout靈活指定格式,則要指定打印參數 [%-5p][%d{HH:mm:ss}][%c-%M] %m%n   [%-5p][%d{HH:mm:ss}][%l] %m%n
log4j.appender.STDOUT.layout.ConversionPattern=[%-5p][%d{yyyy-MM-dd HH:mm:ss sss}][%t][%c-%M][%L](%F:%L) - %m%n
 
 
# QUERY:目的地 -- 輸出到文件(限定每個文件大小)
## 凡是 info、warn、error、fatal 級別的數據都會在這裏執行輸出到 query.log 日誌文件中
##log4j.logger.QUERY=INFO,QUERY
log4j.logger.QUERY=INFO
##輸出到文件(這裏默認爲追加方式),使用org.apache.log4j.FileAppender:日誌會在一個文件中追加
log4j.appender.QUERY=org.apache.log4j.RollingFileAppender
##設置文件輸出路徑;html:log/query.html
log4j.appender.QUERY.File=log/query.log
##設置文件輸出樣式;html格式: org.apache.log4j.HTMLLayout
log4j.appender.QUERY.layout=org.apache.log4j.PatternLayout
## 上一句設置了PatternLayout靈活指定格式,則要指定打印參數 [%-5p][%d{HH:mm:ss}][%l] %m%n
log4j.appender.QUERY.layout.ConversionPattern=[%-5p][%d{yyyy-MM-dd HH:mm:ss}][%c-%M] %m%n
## 指定文件的最大 大小
log4j.appender.QUERY.MaxFileSize=2048KB
## 可被備份的日誌數
log4j.appender.QUERY.MaxBackupIndex=100
 
 
# SYS:目的地 -- 輸出到文件(每天產生一個文件) 
## 凡是 error、fatal 級別的數據都會在這裏執行輸出到 sys.log 日誌文件中
#log4j.logger.SYS=error,SYS
log4j.logger.SYS=error
## org.apache.log4j.RollingFileAppender:每天產生一個日誌文件
#使用org.apache.log4j.FileAppender:日誌會在一個文件中追加
log4j.appender.SYS=org.apache.log4j.DailyRollingFileAppender
##設置文件輸出路徑 ${user.home}/log/sys.log
log4j.appender.SYS.File=log/sys.log
## org.apache.log4j.PatternLayout:靈活地指定佈局模式
log4j.appender.SYS.layout=org.apache.log4j.PatternLayout
## 上一句設置了PatternLayout靈活指定格式,則要指定打印參數 [%-5p][%d{HH:mm:ss}][%l] %m%n
log4j.appender.SYS.layout.ConversionPattern=[%-5p][%d{HH:mm:ss}][%C-%M] %m%n
 
#設置特定包的級別
##com.swh.weixin包下的日誌內容顯示級別爲debug,和目的地
## 把com.swh.weixin.util包下日誌等級爲debug的信息輸出到pack 目的地
#log4j.logger.com.swh.weixin.util=debug,pack
##輸出到文件(這裏默認爲追加方式),使用org.apache.log4j.FileAppender:日誌會在一個文件中追加
log4j.appender.pack=org.apache.log4j.RollingFileAppender
##設置文件輸出路徑  或者 ${user.home}/log/pack.log
log4j.appender.pack.File=log/pack.log
##設置文件輸出樣式
log4j.appender.pack.layout=org.apache.log4j.PatternLayout
## 上一句設置了PatternLayout靈活指定格式,則要指定打印參數 [%-5p][%d{HH:mm:ss}][%l] %m%n
log4j.appender.pack.layout.ConversionPattern=[%-5p][%d{yyyy MM dd HH:mm:ss}][%c-%M] %m%n
## 指定文件的最大 大小
log4j.appender.pack.MaxFileSize=1024KB
#日誌最大備份數目
log4j.appender.pack.MaxBackupIndex=100
 
########################################################################
##設置級別和目的地  
#log4j.rootLogger=debug,appender1,appender2  
##只設置特定包的級別和目的地
#log4j.logger.com.coderdream=debug,appender1
#log4j.logger.com.coderdream.Dao=info,appender1,appender2
 
##輸出到控制檯
#log4j.appender.appender1=org.apache.log4j.ConsoleAppender
##設置輸出樣式
#log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
##自定義樣式
## %r 時間 0
## %t 方法名 main
## %p 優先級 DEBUG/INFO/ERROR
## %c 所屬類的全名(包括包名)
## %l 發生的位置,在某個類的某行
## %m 輸出代碼中指定的訊息,如log(message)中的message
## %n 輸出一個換行符號
#log4j.appender.appender1.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%C-%M] %m%n
 
##輸出到文件(這裏默認爲追加方式)
#log4j.appender.appender2=org.apache.log4j.FileAppender
##設置文件輸出路徑
##【1】文本文件
#log4j.appender.appender2.File=c:/Log4JCRM_Dao.log
##設置文件輸出樣式
#log4j.appender.appender2.layout=org.apache.log4j.PatternLayout
#log4j.appender.appender2.layout.ConversionPattern=[%d{HH:mm:ss:SSS}][%C-%M] -%m%n
 
 
##把日誌文件寫入數據庫
##########################日誌輸出到遠程數據庫########################################
##把日誌文件寫入數據庫
##記錄的日誌級別
log4j.logger.db=info
##日誌輸出到數據庫
log4j.appender.db = org.apache.log4j.jdbc.JDBCAppender
##緩存
log4j.appender.db.BufferSize = 0
##數據庫驅動
log4j.appender.db.Driver = com.mysql.jdbc.Driver
##數據url地址 ,本地可簡寫:jdbc:mysql:///test
log4j.appender.db.URL = jdbc:mysql://localhost:3306/swh_hibernate4?useUnicode=true&characterEncoding=utf8
##數據庫用戶名
log4j.appender.db.User = root
##數據庫密碼
log4j.appender.db.Password = root
##日誌佈局模式
log4j.appender.db.layout = org.apache.log4j.PatternLayout
##日誌插入數據庫中,t_logs 表字段可自定義
log4j.appender.db.layout.ConversionPattern = INSERT INTO t_logs(createDate, thread, priority, category,<br />
methodName, message) values('%d', '%t', '%-5p', '%c','%M', '[%l]-%m')

log4j.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
 
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
 
  <appender name="default" class="org.apache.log4j.ConsoleAppender">
    <param name="target" value="System.out"/>
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="[%-5p] %d{yyyy-MM-dd hh:mm:ss.SSS aa} %t [%c]%n%m%n%n"/>
    </layout>
  </appender>
  
  <appender name="console" class="org.apache.log4j.ConsoleAppender">
    <param name="target" value="System.out"/>
    <!-- 設置日誌文件輸出樣式 -->
    <layout class="org.apache.log4j.PatternLayout">
    <!-- 設置日誌的輸出格式 -->
      <param name="ConversionPattern" value="[%-5p] [%d{yyyy-MM-dd HH:mm:ss.SSS z}] [%t] [%c]%n%m%n%n"/>
    </layout>
  </appender>
  
  <!-- 查詢級別,輸出到文件(限定每個文件大小) -->
   <appender name="query" class="org.apache.log4j.RollingFileAppender">     
   	<!-- 設置日誌輸出文件名 -->    
        <param name="File" value="E:/user-job-web.log" />    
        <!-- 設置是否在重新啓動服務時,在原有日誌的基礎添加新日誌 -->     
        <param name="Append" value="true" />
        <!-- 指定文件的最大 大小爲1MB 單位是B(1024B=1KB) -->     
        <param name="MaxFileSize" value="1048576" />
        <!-- 備份日誌文件的個數(默認是10個) -->
        <param name="MaxBackupIndex" value="10" />     
        <layout class="org.apache.log4j.PatternLayout">     
            <param name="ConversionPattern" value="[%-5p][%d{yyyy-MM-dd HH:mm:ss}][%c-%M] %m%n" />     
        </layout>     
    </appender>     
  
  <!-- 輸出到文件(每天產生一個文件)  -->
  <appender name="sys" class="org.apache.log4j.DailyRollingFileAppender">
  	<!-- 設置日誌輸出文件名 --> 
     <param name="File" value="E:\\user-job-web_warn.log" />       
     <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" /> 
    <!-- 設置日誌文件輸出樣式 -->
    <layout class="org.apache.log4j.PatternLayout">
    <!-- 設置日誌的輸出格式 -->
      <param name="ConversionPattern" value="[%-5p] [%d{yyyy-MM-dd HH:mm:ss.SSS}] [%t] [%c-%M]%n%m%n%n"/>
    </layout>
  </appender>
 
 <!-- 日誌輸出到數據中 -->
   <appender name="dblog" class="org.apache.log4j.jdbc.JDBCAppender">
      <!-- 設置數據庫信息和連接 --> 
     <param name="Driver" value="com.mysql.jdbc.Driver" />       
     <param name="URL" value="jdbc:mysql://localhost:3306/swh_hibernate4?useUnicode=true&characterEncoding=utf8" /> 
     <param name="user" value="root" />
     <param name="password" value="root" />
     <!-- 設置日誌文件輸出樣式 -->
    <layout class="org.apache.log4j.PatternLayout">
    <!-- 設置輸出日誌的sql-->
      <param name="ConversionPattern" value="INSERT INTO t_logs(createDate, thread, priority, category,methodName, message) values('%d', '%t', '%-5p', '%c','%M', '[%l]-%m')"/>
    </layout>
  </appender>
  <!-- 單獨配置,效果和放到logger->root下一樣 -->
  <category name="com.swh.crm.aop" additivity="false">
        <level value="INFO" />
        <appender-ref ref="dblog" />
        <appender-ref ref="console" />
    </category>
 
 <logger name="org.quartz">
   <level value="warn" />
 </logger>
 
 <!-- 設置com.swh.crm.service路徑下的日誌信息級別爲info級別 -->
 <logger name="com.swh.oa.service" additivity="true">
   <level value="info" />
 </logger>
 
<!-- 設置級別和目的地 -->
  <root>
  	<!-- 設置根日誌級別,指定路徑中的日誌優先級大於根日誌優先級
  	(com.swh.crm(只會輸出info級別以上的日誌)>root,
  	 org.quartz(只會輸出warn級別以上的日誌))
  	 沒有指定日誌級別的則以root指定的日誌級別爲準 -->
    <level value="debug" />
    <!-- 引入appender -->
   <!--  <appender-ref ref="sys" /> -->
    <appender-ref ref="query" />
    <appender-ref ref="console" />
  </root>
  
</log4j:configuration>

附:

log4j.rootLogger =ALL,systemOut,logRollingFile
#log4j.rootLogger =ALL,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB 
#\u8F93\u51FA\u5230\u63A7\u5236\u53F0 
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 

#\u8F93\u51FA\u5230\u6587\u4EF6 
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 = WARN 
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 

#\u6309DatePattern\u8F93\u51FA\u5230\u6587\u4EF6 
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 

#\u8BBE\u5B9A\u6587\u4EF6\u5927\u5C0F\u8F93\u51FA\u5230\u6587\u4EF6 
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 = e:/testlog/test.log
log4j.appender.logRollingFile.MaxFileSize = 1MB 
log4j.appender.logRollingFile.MaxBackupIndex = 50 
log4j.appender.logRollingFile.Encoding = UTF-8 

#\u7528Email\u53D1\u9001\u65E5\u5FD7 
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 = [email protected] 
log4j.appender.logMail.To = [email protected] 
#log4j.appender.logMail.Cc = [email protected] 
#log4j.appender.logMail.Bcc = [email protected] 
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 

#\u5C06\u65E5\u5FD7\u767B\u5F55\u5230MySQL\u6570\u636E\u5E93 
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')

參考博客 : https://blog.csdn.net/sanfye/article/details/50392073

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章