博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
shell脚本切割tomcat的日志文件
阅读量:7066 次
发布时间:2019-06-28

本文共 1093 字,大约阅读时间需要 3 分钟。

鉴于在调试logback和log4j的文件切割一直无法成功,随性用shell写个脚本用来切割tomcat下的日志文件(大家如果有在logback或log4j使用文件切割成功的话,可以留下使用方式,先谢谢了)

1:废话少说,直接贴上脚本:

#!/bin/shlog_dir=/var/log/tomcatmonitor_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-cronyum install crontabs

若文章在表述和代码方面如有不妥之处,欢迎批评指正。留下你的脚印,欢迎评论!希望能互相学习

转载于:https://www.cnblogs.com/lishun1005/p/6054816.html

你可能感兴趣的文章
warning no match for this type name:xxx.xxx.xxx [Xlint:invalidAbsoluteTypeName]
查看>>
java.lang.ClassNotFoundException: com.sun.jna.Native
查看>>
Restful架构风格详解
查看>>
读书笔记10:外观模式
查看>>
java类加载器的父亲委托机制详细介绍
查看>>
莫名奇妙的异常001:Invalid or unexpected token
查看>>
linux下smb打印服务器部署过程(对windows终端)
查看>>
WIN7下使用Outlook访问 Exange2010 无法对外发送邮件的问题
查看>>
寒门难再出贵子(4),一篇值得思考的文章
查看>>
DataUml Design 教程7 - 数据库生成模型
查看>>
常用的数据库连接写法
查看>>
bitmap算法
查看>>
base64图上上传保存到服务器
查看>>
乔春洋:文化资源与文化产业化
查看>>
有关libpthread.so库的问题
查看>>
使用zt-exec库定时清理linux休眠进程
查看>>
比较好用的js文字无缝滚动,支持ff ie678
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
VSAN 和 vSphere Replication 的互操作
查看>>