Tomcat日志切割总结[通俗易懂]

Tomcat日志切割总结[通俗易懂]目录目录前言1.创建shell脚本进行catalina.out日志文件切割2.使用log4j成功使catalina.out文件实现分割3.用cronolog软件来分割Tomcat的catalina.out文件假设我们想日志以catalina.2018-08-31.out这种方式分割前言我们都知道将一个项目部署到Tomcat之后,Tomcat服…

大家好,又见面了,我是你们的朋友全栈君。

目录

前言

我们都知道将一个项目部署到Tomcat之后,Tomcat服务启动后的标准输出(stdout)和标准出错(stderr)都会默认重定向到${TOMCAT_HOME}/logs/catalina.out这个文件中,有时候短短一会儿这个文件就能达到几十兆甚至上百兆,日积月累这个文件如果不及时清理将会占用服务器磁盘大量空间从而影响到整个项目的正常运行;
再者这样大日志文件对于我们进行错误排查以及日志分析都不是很方便,一次打开也花上好几分钟,直接cat命令查看也要滚掉好多屏,并且那时候想要来切割的话又异常麻烦。
所以,现在我们提前做好用日期来分割日志的配置,即Tomcat运行的每天都按照日期命名新建一个日志文件。

1. 创建shell脚本进行catalina.out日志文件切割

编写一个.sh文件并赋予文件执行全向最后放入$TOMCAT_HOME/bin目录下面,然后结合linux系统自带的定时器进行Tomcat日志切割。Shell脚本如下:

#!/bin/bash 
cd  `dirname $0`                           ##进入执行脚本所在目录,我这里是$TOMCAT_HOME/bin
d=`date +%Y%m%d`                           ##获取当前日期
d7=`date -d'7 day ago' +%Y%m%d`            ##获取7天前的日期

cd  ../logs/                               ##进入日志所在目录
cp catalina.out   catalina.out.${d}        ##将当前日志的内容拷贝到以日期分割的新文件中,
echo "" > catalina.out                     ##并清空当前日志文件的内容
rm -rf catalina.out.${d7}                  ##删除七天前的日志

值得一提的是:执行这个脚本的定时任务的频率以及时间都要控制好,不然会有部分日志内容保存不下来的情况。

2. 使用log4j成功使catalina.out文件实现分割

在Tomcat根目录下建立 /webapps/项目名/WEB-INF/classes/log4j.properties,内容如下:

############################################################################ 
log4j.rootLogger=INFO, R 
log4j.appender.R=org.apache.log4j.RollingFileAppender 
log4j.appender.R.File=${TOMCAT_HOME}/logs/tomcat.newlog    #设定日志文件名
log4j.appender.R.MaxFileSize=100KB                          #设定文件到100kb即分割
log4j.appender.R.MaxBackupIndex=10                          #设定日志文件保留的序号数
log4j.appender.R.layout=org.apache.log4j.PatternLayout 
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
############################################################################

注意:以上配置需要在Tomcat根目录下的 /webapps/项目名/WEB-INF/lib目录下加入log4j.jar和commons-logging.jar,然后重新启动Tomcat服务即可生效。

3. 用cronolog软件来分割Tomcat的catalina.out文件

  • 下载cronolog软件压缩包
[root@localhost ~]# cd /home/tools
[root@localhost tools]# wget http://cronolog.org/download/cronolog-1.6.2.tar.gz 
  • 解压软件包
[root@localhost tools]# tar xf cronolog-1.6.2.tar.gz 
  • 进入cronolog安装包
[root@localhost tools]# cd cronolog-1.6.2 
  • 运行安装
[root@localhost cronolog-1.6.2]# ./configure 
[root@localhost cronolog-1.6.2]# make 
[root@localhost cronolog-1.6.2]# make install 
  • 查看cronolog安装后所在目录(验证安装是否成功)
 [root@localhost cronolog-1.6.2] # which cronolog 
 /usr/local/sbin/cronolog

假设我们想日志以catalina.2018-08-31.out这种方式分割

  • 编辑tomcat下的/bin/catalina.sh脚本文件
org.apache.catalina.startup.Bootstrap “$@” start  \   
>> “$CATALINA_BASE”/logs/catalina.out 2>&1 & 
#将上面两行内容替换为以下内容:
org.apache.catalina.startup.Bootstrap "$@" start  2>&1 \   
| /usr/local/sbin/cronolog "$CATALINA_BASE"/logs/catalina.%Y-%m-%d.out >> /dev/null &  

#然后再注释掉:
touch “$CATALINA_BASE”/logs/catalina.out
#其实touch catalina.out(创建这个文件)的语句,注不注掉都无所谓,反正修改成功了里面不会有东西的。
  • 编辑Tomcat下的/conf/logging.properties日志配置文件
#注释掉以下内容:
catalina.org.apache.juli.FileHandler.prefix = catalina.  

Tomcat根目录/conf/logging.properties配置还牵涉一些其他相关的输出,不想输出其他的,就把相关的注掉,比如不想输出host-manager**.log的日志,就注掉以下行:

#4host-manager.org.apache.juli.FileHandler.level = FINE
#4host-manager.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
#4host-manager.org.apache.juli.FileHandler.prefix = host-manager.
#org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/host-manager].level = INFO
#org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/host-manager].handlers = 4host-manager.org.apache.juli.FileHandler
  • 重启Tomcat服务查看配置是否成功

查看tomcat下的/logs/目录下看看日志是不是输入到按日期分割的日志文件里了,然后把服务所在主机的系统时间修改一下,比如修改到:下一天的23:58:00过两分钟,是不是又出现一个日志文件了?

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/151408.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(2)


相关推荐

  • 一文详解深度相机之TOF成像[通俗易懂]

    一文详解深度相机之TOF成像[通俗易懂]点击上方“计算机视觉工坊”,选择“星标”干货第一时间送达文章导读本文通过介绍TOF相机的成像过程,带大家了解TOF相机中脉冲法和连续波调制这两种技术原理,并详细的分析每种方法的实现细节和各…

  • leetcode-1840. 最高建筑高度

    leetcode-1840. 最高建筑高度在一座城市里,你需要建 n 栋新的建筑。这些新的建筑会从 1 到 n 编号排成一列。这座城市对这些新建筑有一些规定:每栋建筑的高度必须是一个非负整数。第一栋建筑的高度 必须 是 0 。任意两栋相邻建筑的高度差 不能超过 1 。除此以外,某些建筑还有额外的最高高度限制。这些限制会以二维整数数组 restrictions 的形式给出,其中 restrictions[i] = [idi, maxHeighti] ,表示建筑 idi 的高度 不能超过 maxHeighti 。题目保证每栋建筑在 res

  • linux下yum命令出现Loaded plugins: fastestmirror

    linux下yum命令出现Loaded plugins: fastestmirror

  • java类加载和初始化_java静态变量什么时候初始化

    java类加载和初始化_java静态变量什么时候初始化????Java学习路线配套文章:Java学习路线总结,搬砖工逆袭Java架构师(全网最强)????基础推荐:Java基础教程系列????实战推荐:SpringBoot基础教程????简介:Java领域优质创作者????、CSDN哪吒公众号作者✌、Java架构师奋斗者????????扫描主页左侧二维码,加入群聊,一起学习、一起进步????欢迎点赞????收藏⭐留言????目录一、类的加载与ClassLoader的理解1、加载2、链接3、初始化二、什么时候会发生类初始化1

  • 电脑爱好者2012年5-12期「建议收藏」

    电脑爱好者2012年5-12期「建议收藏」电脑爱好者2012年第05期全彩高清PDF免费高速下载.pdf电脑爱好者2012年第06期全彩高清PDF免费高速下载.pdf电脑爱好者2012年第07期全彩高清PDF免费高速下载.pdf电脑爱好者201…

  • xps 转 pdf android版,OakDoc XPS to PDF Converter(XPS文件转PDF格式工具)V2.2 正式版

    xps 转 pdf android版,OakDoc XPS to PDF Converter(XPS文件转PDF格式工具)V2.2 正式版OakDocXPStoPDFConverter(XPS文件转PDF格式工具)是一款很优秀好用的XPS转PDF的辅助工具。如果你需要一款好用的文件转换工具,小编带来的这款OakDocXPStoPDFConverter软件是很不错的选择,功能强大全面,使用后可以帮助用户轻松将XPS文件转换成PDF格式。软件可帮助用户通过简单的方式将XPS文件转换输出为PDF为主的主流图片格式。该工具的…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号