下面給出了log4j.properties文件經常使用的一些信息,在使用時只需拷貝部分過來並把註釋放開便可,若有問題 感謝留言指正.html
##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')
<?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>