使用脚本方式进行日志切割
#!/bin/bash
SOFTROOT=/usr/local/nginx/logs
if [ ! -d $SOFTROOT ]; then
exit 0
fi
cp $SOFTROOT/access.log $SOFTROOT/access.log.`date +%Y%m%d`
echo "" > $SOFTROOT/access.log
把脚本放到计划任务中,每天晚上23点59分执行即可
[root@test logs]# crontab -e
59 23 * * * /data/soft/log.sh > /dev/null &
当然也可以在0点0分执行,保存为前一天的日期
cp $SOFTROOT/access.log $SOFTROOT/access.log.`date -d '-1 days' +%Y%m%d`
或
cp $SOFTROOT/access.log $SOFTROOT/access.log.`date -d "yesterday" +"%Y%m%d"`
[root@test logs]# crontab -e
0 0 * * * /data/soft/log.sh > /dev/null &
注:
1、echo “” >可以运用在正在运行的log日志文件中
2、如果是nginx,也可以先使用mv 再使用以下命令 来让主进程重新生成日志文件
[root@test logs]# kill -USR1 `cat /usr/local/nginx/logs/nginx.pid `
或
[root@ecs-8395 logs]# /usr/local/nginx/sbin/nginx -s reload
3、删除80天前的日志
find /xxx/logs/ -mtime +80 -name "*.log" -exec rm -rf {} \;
----------------------end