方案一
使用cronolog分割tomcat的catalina.out文件,并且crontab进行定时删除日志。
日志按照时间分隔
我们采用日期形式切割catalina.out 日志,因此采用cronlog 软件切割:
- 安装 cronlog
yum install -y cronolog httpd
或者
sudo apt-get install gcc
wget http://cronolog.org/download/cronolog-1.6.2.tar.gz
tar -xzvf cronolog-1.6.2.tar.gz
cd cronolog-1.6.2
./configure
make
sudo suroot
make install
查看cronolog是否安装: whereis cronolog
- 修改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
(2) touch "$CATALINA_OUT"
改为:
#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&
- 重启tomcat服务。
至此,tomcat日志便会以每天的形式进行输出,不再只输出到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文件,可指定具体的用户
加入我们的定时任务(表示每天2点30分跑一次脚本):
30 2 * * * /usr/local/auto_del_log.sh >/dev/null 2>&1
方案二
通过定时任务,每天复制catalina.out文件,并删除历史文件方式。
- crontab安装同上
- 脚本如下
#!/bin/bash
log_path=/usr/local/apache-tomcat-8/logs
d=`date +%Y-%m-%d`
#7天前日志要被清除
d4=`date -d '7 day ago' +%Y-%m-%d`
cd ${log_path} && cp catalina.out $log_path/catalina.out.$d.log
#清空catalina.out日志
echo > catalina.out
rm -rf $log_path/catalina.out.${d4}.log
rm -rf $log_path/*.${d4}.log
rm -rf $log_path/*.${d4}.txt