[轉]log4j日誌資訊配置檔案詳解
阿新 • • 發佈:2019-01-05
使用log4j 記錄日誌甚是方便,其提供了兩種日誌配置方式,log4j.propertes和log4j.xml,這篇檔案先貼出log4j.properties配置方式
1、log4j.properties檔案配置簡析
下面給出了log4j.properties檔案常用的一些資訊,在使用時只需拷貝部分過來並把註釋放開即可,如有問題 感謝留言指正.
##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>