标签:shell 定义 cron 过多 意义 日志记录 查看 注意 编写
日志切割的意义:在生产环境中,当我们使用tomcat服务时,如果用户量过多,有没有日志切割,将会产生很大的日志,一天的日志都能有好几个G大小。当我们需要查看日志记录时,非常麻烦。因此,日志切割是很有必要的!
vim fengelog.sh
#脚本声明
#!/bin/bash
. /etc/profile
. ~/.bash_profile
#定义日志文件目录
applog_path=/usr/local/apache-tomcat-app/logs
sapplog_path=/usr/local/apache-tomcat-sapp/logs
#定义日期格式
d=`date +%Y-%m-%d-%H:%M`
d15=`date -d‘15 day ago‘ +%Y-%m-%d` #15天的日期
#切割日志
cd ${applog_path} && cp catalina.out $applog_path/$d.log #日志备份
echo > catalina.out #原日志清空
rm -rf $applog_path/${d15}*.log #保留15天的日志
cd ${sapplog_path} && cp catalina.out $sapplog_path/$d.log #日志备份
echo > catalina.out #原日志清空
rm -rf $sapplog_path/${d15}*.log #保留15天的日志
chmod +x fengelog.sh
sh fengelog.sh
crontab -e
0 */3 * * * sh /root/fengelog.sh
#设置每3个小时切割一次日志
1.脚本中开头. /etc/profile ,. ~/.bash_profile 是为了让定时任务可以成功执行添加的环境变量,如果不加,定时任务不会执行!
2.日志保留的时间和一次切割tomcat日志的数量,多长时间切割日志都是可以自定义的。
3.建议脚本写好后,先自己运行一下,确定没有问题,在加入定时任务里面!
标签:shell 定义 cron 过多 意义 日志记录 查看 注意 编写
原文地址:https://blog.51cto.com/13760351/2467262