欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

详解关于tomcat切割catalina.out日志的三种方式

程序员文章站 2022-06-27 19:05:32
1.log4j进行日志切分 1)准备三个包:log4j-1.2.17.jar      tomcat-juli.jar  &nbs...

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-manager

3)再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(注:行数不一定是我这个,找到语句为主)

详解关于tomcat切割catalina.out日志的三种方式

将以上两处内容替换为:

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.gz
    compress         通过gzip压缩转储以后的日志(gzip -d xxx.gz解压)
    notifempty       如果是空文件的话,不转储

copytruncate    用于还在打开中的日志文件,把当前日志备份并截断

/usr/local/tomcat7.0.79/logs/catalina.out   指定catalina.out的路径

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。