隨着系統使用時間的增加,Tomcat日誌也愈來愈大,動則幾百G的存儲,佔用磁盤空間不說,還影響性能。咱們須要的是可以自動按照日誌文件大小切割日誌,並只保留最近的5份日誌文件,其他的自動刪除。mysql
按照該方案,經過查詢方案,獲得基於log4j就能夠實現tomcat日誌切割。具體步驟以下:web
到tomcat官網下載tomcat版本對應的tomcat-juli.jar、tomcat-juli-adapters.jar;sql
下載地址:http://www.apache.org/dist/tomcat
數據庫
將tomcat-juli.jar上傳覆蓋到tomcat的bin目錄下;apache
將tomcat-juli-adapters.jar上傳到lib目錄下;tomcat
將log4j相關jar包上傳到lib目錄下;app
將log4j.properties也上傳到lib目錄下,並配置樣例以下:socket
log4j.rootLogger=INFO,logs log4j.appender.logs=org.apache.log4j.RollingFileAppender log4j.appender.logs.File=${catalina.home}/logs/tomcat-all-info.log #每一個備份的日誌文件大小 log4j.appender.logs.MaxFileSize=20MB #備份的日誌文件數目 log4j.appender.logs.MaxBackupIndex=5 log4j.appender.logs.layout=org.apache.log4j.PatternLayout log4j.appender.logs.layout.ConversionPattern=%d{HH:mm:ss} %-5p [%c] (%F:%L) - %m%n
6.將Tomcat 的 conf/logging.properties 文件重命名。性能
7. 修改conf目錄下的context.xml,將this
<context>
改成:
<context swallowOutput="true"> 增長 swallowOutput="true" 的屬性配置,只有這樣才能徹底的把tomcat的stdout給接管過來。這一步很關鍵 在官網及網上找了許多資料都沒有說起。
--------------------------------------------------------------------------------------------------------------------------
log4j.rootLogger=DEBUG,CONSOLE,A1,im log4j.addivity.org.apache=true # 應用於控制檯 log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.Threshold=DEBUG log4j.appender.CONSOLE.Target=System.out log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n #log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n #應用於文件 log4j.appender.FILE=org.apache.log4j.FileAppender log4j.appender.FILE.File=file.log log4j.appender.FILE.Append=false log4j.appender.FILE.layout=org.apache.log4j.PatternLayout log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n # Use this layout for LogFactor 5 analysis # 應用於文件回滾 log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender log4j.appender.ROLLING_FILE.Threshold=ERROR log4j.appender.ROLLING_FILE.File=rolling.log log4j.appender.ROLLING_FILE.Append=true log4j.appender.ROLLING_FILE.MaxFileSize=10KB log4j.appender.ROLLING_FILE.MaxBackupIndex=1 log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n #應用於socket log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender log4j.appender.SOCKET.RemoteHost=localhost log4j.appender.SOCKET.Port=5001 log4j.appender.SOCKET.LocationInfo=true # Set up for Log Facter 5 log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout log4j.appender.SOCET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n # Log Factor 5 Appender log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000 # 發送日誌給郵件 log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender log4j.appender.MAIL.Threshold=FATAL log4j.appender.MAIL.BufferSize=10 log4j.appender.MAIL.From=web@www.wuset.com log4j.appender.MAIL.SMTPHost=www.wusetu.com log4j.appender.MAIL.Subject=Log4J Message log4j.appender.MAIL.To=web@www.wusetu.com log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n # 用於數據庫 log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver log4j.appender.DATABASE.user=root log4j.appender.DATABASE.password= log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n') log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender log4j.appender.A1.File=SampleMessages.log4j log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j' log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout