随着天天业务的增加,Tomcat 的catalina.out日志 变得愈来愈大,占用磁盘空间不说。要查看某个时候的日志的时候,庞大的日志让你顿时无从下手,因此日志的切割的变得刻不容缓。并且,切割后的日志,还能够按期清理掉久远的日志......linux
咱们采用日期形式切割catalina.out 日志,所以采用cronlog 软件切割:apache
一、安装 cronlog ide
yum install -y cronolog httpdspa
二、修改bin/catalina.sh文件日志
(1) if [ -z "$CATALINA_OUT" ] ; thencode
CATALINA_OUT="$CATALINA_BASE"/logs/catalina.out
fiblog
改成:crontab
if [ -z "$CATALINA_OUT" ] ; then
CATALINA_OUT="$CATALINA_BASE"/logs/%Y-%m-%d.catalina.out
fiip
(2) touch "$CATALINA_OUT"event
改成:
#touch "$CATALINA_OUT"
(3) 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&
备注:这里有两处这个样子的,彷佛改下面那处就能够了,我是把两处都改了...
三、重启服务便可。
tips:不能再用原来的catalina.out 来输出日志了哦,由于刚刚不是被咱们注释掉了...
想要写一个Shell脚本,按期清理掉久远的日志文件 ,避免磁盘不断被占用。
一、建立Shell 脚本:
touch auto_del_log.sh
chmod +x auto_del_log.sh
#!/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:强制删除文件,包括目录;
{} \; :固定写法,一对大括号+空格+\+;
二、安装定时器 crontabs
yum install crontabs
/sbin/service crond start //启动服务
三、加入定时任务
crontab -e //编辑当前用户的crontab文件,可指定具体的用户
加入咱们的定时任务(表示天天4点10分跑一次脚本):10 4 * * * /usr/local/auto_del_log.sh >/dev/null 2>&1