Tomcat使用Log4j輸出catalina.out日志
Tomcat默認(rèn)的日志是用java.util.logging,有幾點(diǎn)不足,文件catalian.out不能像log4j一樣按天生成,將越來越大。日志格式和項(xiàng)目中用log4j打出來的不一致,不利于解析。
從tomcat官網(wǎng)(https://tomcat.apache.org/tomcat-7.0-doc/logging.html)上找了下,修改一些配置、替換擴(kuò)展包即可使用log4j輸出catalian.out。
在$CATALINA_BASE/lib下創(chuàng)建log4j.properties文件
log4j.properties的內(nèi)容如下:
log4j.rootLogger = INFO, CATALINA # Define all the appenders log4j.appender.CATALINA = org.apache.log4j.DailyRollingFileAppender log4j.appender.CATALINA.File = ${catalina.base}/logs/catalina.out log4j.appender.CATALINA.Append = true log4j.appender.CATALINA.Encoding = UTF-8 # Roll-over the log once per day log4j.appender.CATALINA.DatePattern = '.'yyyy-MM-dd log4j.appender.CATALINA.layout = org.apache.log4j.PatternLayout #log4j.appender.CATALINA.layout.ConversionPattern = %d [%t] %-5p %c- %m%n log4j.appender.CATALINA.layout.ConversionPattern =%d{yyyy-MM-dd HH:mm:ss.SSS} %p [%t] %c | %m%n # configure customed log to catalina.out log4j.logger.com.xxxxx = WARN, CATALINA log4j.logger.org.apache = WARN, CATALINA log4j.logger.org.mybatis = WARN, CATALINA log4j.logger.java.sql = WARN, CATALINA log4j.logger.org.springframework = WARN, CATALINA
更新tomcat相關(guān)jar包
下載log4j-1.2.17.jar(http://www.apache.org/dist/logging/log4j/1.2.17/)
下載tomcat7的2個(gè)jar包:tomcat-juli.jar 和 tomcat-juli-adapters.jar(http://www.apache.org/dist/tomcat/tomcat-7/v7.0.69/bin/extras/ 最好和tomcat版本對應(yīng))
把log4j-1.2.17.jar和tomcat-juli-adapters.jar放到$CATALINA_HOME/lib下;用新下載的tomcat-juli.jar包替換掉$CATALINA_HOME/bin/tomcat-juli.jar包。
刪除$CATALINA_BASE/conf/logging.properties。
重啟tomcat
關(guān)于默認(rèn)的catalina日志格式
如果只想修改tomcat默認(rèn)的日志格式,替換掉默認(rèn)的java.util.logging.SimpleFormatter
即可。SimpleFormatter類里format格式為LoggingSupport.getSimpleFormat()
,它的具體值是:"%1$tb %1$td, %1$tY %1$tl:%1$tM:%1$tS %1$Tp %2$s%n%4$s: %5$s%6$s%n",其中時(shí)間格式可能不是我們期望的,還有里面有個(gè)換行%n。比如想改為類似上面log4j的時(shí)間格式,可自己重寫一個(gè)替換類(com.xxx.LogFormatter),format設(shè)為"%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS.%1$tL %4$s %2$s %5$s%6$s%n"。修改$CATALINA_BASE/conf/logging.properties
java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter
改為如下:
java.util.logging.ConsoleHandler.formatter = com.xxx.LogFormatter org.apache.juli.FileHandler.formatter = com.xxx.LogFormatter
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
Tomcat配置HTTPS訪問的實(shí)現(xiàn)步驟
本文主要介紹了Tomcat配置HTTPS訪問的實(shí)現(xiàn)步驟,在tomcat中存在兩種證書驗(yàn)證情況單向驗(yàn)證和雙向驗(yàn)證,下面就詳細(xì)的介紹一下這兩種情況的配置,感興趣的可以了解一下2022-07-07tomcat訪問(access)日志配置和記錄Post請求參數(shù)
這篇文章主要介紹了tomcat訪問(access)日志配置和記錄Post請求參數(shù),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03教你在IDEA中使用Tomcat部署并啟動(dòng)Web項(xiàng)目
這篇文章主要介紹了教你在IDEA中使用Tomcat部署并啟動(dòng)Web項(xiàng)目,IDEA作為一款主流的開發(fā)工具其實(shí)已經(jīng)集成了Tomcat的部分功能,需要的朋友可以參考下2023-03-03tomcat logs 目錄下各日志文件的解析(小結(jié))
這篇文章主要介紹了tomcat logs 目錄下各日志文件的含義,包括catalina.日期.log,commons-daemon.日期.log,host-manager.日期.log,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-12-12