如何处理生产环境Tomcat的catalina.out日志?

# 前言

 

随着每天业务的增长,Tomcat 的catalina.out日志 变得越来越大,占用磁盘空间不说。要查看某个时候的日志的时候,庞大的日志让你顿时无从下手,所以日志的切割的变得刻不容缓。而且,切割后的日志,还可以定期清理掉久远的日志。

 

# Tomcat 日志分割

 

我们采用日期形式切割catalina.out 日志,因此采用cronlog 软件切割。

 

1、安装 cronlog

 

yum install -y cronolog httpd

2、修改bin/catalina.sh文件

第一步:

 

 

 

 

if [ -z "$CATALINA_OUT" ] ; then

 

CATALINA_OUT="$CATALINA_BASE"/logs/catalina.out

 

fi

改为:

 

 

 

if [ -z "$CATALINA_OUT" ] ; then

 

CATALINA_OUT="$CATALINA_BASE"/logs/%Y-%m-%d.catalina.out

 

fi

第二步:

 

touch "$CATALINA_OUT"

改为:

 

#touch "$CATALINA_OUT"

第三步:

 

 

org.apache.catalina.startup.Bootstrap "$@" start \

 

>> "$CATALINA_OUT" 2>&1 "&"

改为:

 

 

org.apache.catalina.startup.Bootstrap "$@" start 2>&1

 

| /usr/sbin/cronolog "$CATALINA_OUT" >> /dev/null&

备注:这里有两处这个样子的,似乎改下面那处就可以了,我是把两处都改了。

3、重启服务即可。

 

tips:不能再用原来的catalina.out 来输出日志了哦,因为刚刚不是被我们注释掉了。

# 定时清理日志

 

想要写一个Shell脚本,定期清理掉久远的日志文件 ,避免磁盘不断被占用。

 

1、创建Shell 脚本

 

br

 

 

 

#!/bin/sh

 

find /usr/local/fz_regulator/logs/ -mtime +60 -name "*.out" -exec rm -rf {} ;

 

find /usr/local/fz_middlekey/logs/ -mtime +60 -name "*.out" -exec rm -rf {} ;

find:linux的查找命令,用户查找指定条件的文件;

 

/usr/local/fz_middlekey/logs/:想要进行清理的任意目录;

 

-mtime:标准语句写法;

 

+60:查找60天前的文件,这里用数字代表天数;

 

".out":希望查找的数据类型,".jpg"表示查找扩展名为jpg的所有文件,"*"表示查找所有文件,这个可以灵活运用,举一反三;

 

-exec:固定写法;

 

rm -rf:强制删除文件,包括目录;

 

{} ; :固定写法,一对大括号+空格++。

 

2、安装定时器 crontabs

 

 

yum install crontabs

 

/sbin/service crond start //启动服务

3、加入定时任务

crontab -e //编辑当前用户的crontab文件,可指定具体的用户

加入我们的定时任务(表示每天4点10分跑一次脚本):

 

10 4 * * * /usr/local/auto_del_log.sh >/dev/null 2>&1

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值