共计 1721 个字符,预计需要花费 5 分钟才能阅读完成。
鉴于在调试 logback 和 log4j 的文件切割一直无法成功,随性用 shell 写个脚本用来切割 tomcat 下的日志文件(大家如果有在 logback 或 log4j 使用文件切割成功的话,可以留下使用方式,先谢谢了)
1:废话少说,直接贴上脚本:
#!/bin/sh
log_dir=/var/log/tomcat
monitor_file=$1 #tomcat 目录下的 catalina.out 文件的绝对路径
file_size=`du -m $monitor_file | awk ‘{print $1}’`
if [$file_size -ge 100]
then
if [! -d $log_dir]
then
mkdir /var/log/tomcat #创建保存切割文件目录, 这个路径可以自行修改,保存到你想要的目录
fi
cp $1 /var/log/tomcat/log-`date +%Y-%m-%d-%H%M%S`.log #保存日志文件
echo `date +%Y-%m-%d-%H:%M:%S`”: 文件切割 ” >>/var/log/tomcat/split.log #记录切割日志
echo “” > $1 #清空 tomcat 的 log/catalina.out 文件内容
fi
说明:这个脚本很简单,linux 用个定时器没分钟定时扫描日志文件的大小, 就是当文件大于 100M 的时候,先把文件复制到指定的目录,再清空原先 tomcat 的日志文件。这里是用 crontab 来使用定时器,至于这个命令的语法在这里就不多说,有兴趣的可以自行 google,这里还是有个小小的不足,因为是按每分钟定时去扫描日志文件,所以最后切割文件大小还是会在 100~102M 之间。
然后就用定时器,定时执行这个脚本
2:用 crontab -e 编辑定时器代码
*/1 * * * * sh /lee_js/monitor_script.sh /opt/apache-tomcat-7.0.67/logs/catalina.out #第一个路径是脚本的路径,第二个参数是 tomcat 下 catalina.out 文件的绝对路径
然后保存
至此搞定日志切割
注:若没有 crontab 命令 可使用 yum 安装:
yum install vixie-cron
yum install crontabs
若文章在表述和代码方面如有不妥之处,欢迎批评指正。留下你的脚印,欢迎评论!希望能互相学习
更多 Tomcat 相关教程见以下内容:
CentOS 6.6 下安装配置 Tomcat 环境 http://www.linuxidc.com/Linux/2015-08/122234.htm
RedHat Linux 5.5 安装 JDK+Tomcat 并部署 Java 项目 http://www.linuxidc.com/Linux/2015-02/113528.htm
Tomcat 权威指南(第二版)(中英高清 PDF 版 + 带书签) http://www.linuxidc.com/Linux/2015-02/113062.htm
Tomcat 安全配置与性能优化 http://www.linuxidc.com/Linux/2015-02/113060.htm
Linux 下使用 Xshell 查看 Tomcat 实时日志中文乱码解决方案 http://www.linuxidc.com/Linux/2015-01/112395.htm
CentOS 64-bit 下安装 JDK 和 Tomcat 并设置 Tomcat 开机启动操作步骤 http://www.linuxidc.com/Linux/2015-01/111485.htm
CentOS 6.5 下安装 Tomcat http://www.linuxidc.com/Linux/2015-01/111415.htm
Tomcat 中 session 的管理机制 http://www.linuxidc.com/Linux/2016-09/135072.htm
Tomcat 的详细介绍:请点这里
Tomcat 的下载地址:请点这里
本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-11/137032.htm