catalina.out即tomcat的标准输出和标准出错,所有输出到这两个位置的都会进入catalina.out,这里包含tomcat运行自己输出的日志以及应用里向console输出的日志。本文讲解关于tomcat切割catalina.out日志的三种方式
1.log4j进行日志切分
1)准备三个包:log4j-1.2.17.jar tomcat-juli.jar tomcat-juli-adapters.jar 放到tomcat的lib目录或者是工程的web_inf/lib下,
2)在lib目录下新建log4j.properties,加入以下内容
log4j.rootlogger = info, catalina
# define all the appenders
log4j.appender.catalina = org.apache.log4j.dailyrollingfileappender
log4j.appender.catalina.file = ${catalina.base}/logs/catalina
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'.log'
log4j.appender.catalina.layout = org.apache.log4j.patternlayout
log4j.appender.catalina.layout.conversionpattern = %d [%t] %-5p %c- %m%n
log4j.appender.localhost = org.apache.log4j.dailyrollingfileappender
log4j.appender.localhost.file = ${catalina.base}/logs/localhost
log4j.appender.localhost.append = true
log4j.appender.localhost.encoding = utf-8
log4j.appender.localhost.datepattern = '.'yyyy-mm-dd'.log'
log4j.appender.localhost.layout = org.apache.log4j.patternlayout
log4j.appender.localhost.layout.conversionpattern = %d [%t] %-5p %c- %m%n
log4j.appender.manager = org.apache.log4j.dailyrollingfileappender
log4j.appender.manager.file = ${catalina.base}/logs/manager
log4j.appender.manager.append = true
log4j.appender.manager.encoding = utf-8
log4j.appender.manager.datepattern = '.'yyyy-mm-dd'.log'
log4j.appender.manager.layout = org.apache.log4j.patternlayout
log4j.appender.manager.layout.conversionpattern = %d [%t] %-5p %c- %m%n
log4j.appender.host-manager = org.apache.log4j.dailyrollingfileappender
log4j.appender.host-manager.file = ${catalina.base}/logs/host-manager
log4j.appender.host-manager.append = true
log4j.appender.host-manager.encoding = utf-8
log4j.appender.host-manager.datepattern = '.'yyyy-mm-dd'.log'
log4j.appender.host-manager.layout = org.apache.log4j.patternlayout
log4j.appender.host-manager.layout.conversionpattern = %d [%t] %-5p %c- %m%n
log4j.appender.console = org.apache.log4j.consoleappender
log4j.appender.console.encoding = utf-8
log4j.appender.console.layout = org.apache.log4j.patternlayout
log4j.appender.console.layout.conversionpattern = %d [%t] %-5p %c- %m%n
# configure which loggers log to which appenders
log4j.logger.org.apache.catalina.core.containerbase.[catalina].[localhost] = info, localhost
log4j.logger.org.apache.catalina.core.containerbase.[catalina].[localhost].[/manager] =\
info, manager
log4j.logger.org.apache.catalina.core.containerbase.[catalina].[localhost].[/host-manager] =\
info, host-manager3)再tomcat根目录下,conf文件夹下,删除或者重命名logging.properties文件。然后修改context.xml文件,在<context> 标签修改为<context swallowoutput=”true”>,以接管tomcat的日志输出。这样,使用log4j进行日志切分就完成了。
2、使用cronolog进行切分日志
cronolog是一个过滤器程序,它从标准输入读取日志文件条目,并将每个条目写入由文件名模板和当前日志所指定的输出文件中。 当扩展文件名改变时,关闭当前文件,并打开一个新文件。cronolog是为了与apache等web服务器一起使用,将访问日志分为每日或每月日志。
# wget https://files.cnblogs.com/files/crazyzero/cronolog-1.6.2.tar.gz
# tar -zxf cronolog-1.6.2.tar.gz
# cd cronolog
# ./configure
# make && make install# which cronolog
# /usr/local/sbin/cronolog编辑tomcat下的bin/catalina.sh(注:行数不一定是我这个,找到语句为主)
将以上两处内容替换为:
org.apache.catalina.startup.bootstrap $@ start \
2>&1 |/usr/local/sbin/cronolog $catalina_base/logs/catalina-%y-%m-%d.out &完成后,重新启动tomcat即可。
3、使用logrotate进行切割。
在/etc/logrotate.d下,新建tomcatrotate,编辑tomatrotate,写入如下内容:
/usr/local/tomcat7.0.79/logs/catalina.out {
daily
rotate 15
missingok
dateext
compress
notifempty
copytruncate
}daily 指定转储周期为每天rotate 15 指定日志文件删除之前转储的次数,0指没有备份,5指保留5个备份missingok 如果日志不存在则忽略该警告信息dateext 文件后缀是日期格式,也就是切割后文件是:xxx.log-20150828.gzcompress 通过gzip压缩转储以后的日志(gzip -d xxx.gz解压)notifempty 如果是空文件的话,不转储copytruncate 用于还在打开中的日志文件,把当前日志备份并截断/usr/local/tomcat7.0.79/logs/catalina.out 指定catalina.out的路径
word如何保存文件格式为纯文本格式?网站代码怎么传到虚拟主机腾讯云618云聚惠活动:腾讯云服务器1核2G首年95元堡垒机品牌云服务器哪个好性价比高使用云服务器的网站腾讯云服务器挂本地硬盘安全吗可靠吗天猫新店该如何运营