Nginx脚本方式切割日志
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nginx脚本方式切割日志相关的知识,希望对你有一定的参考价值。
#!/bin/bash
#nginx的log日志目录
log_path=‘/opt/app/nginx/logs/‘
#Nginx的pid文件存放目录
pid_path="${log_path}nginx.pid"
#清理掉指定日期前的日志
DAYS=60
#生成昨天的日志文件
#若指定10天前 date -d"10 day ago 2017-06-08" +%Y-%m-%d
mv ${log_path}access.log ${log_path}access_$(date -d "yesterday" +"%Y%m%d").log
mv ${log_path}error.log ${log_path}error_$(date -d "yesterday" +"%Y%m%d").log
kill -USR1 `cat ${pid_path}`
#文件夹大小转换成M
#文件大小默认是字节
size=`du -b ${log_path} | awk ‘{print int($1/1024/1024)}‘`
#删除60天前的文件
if [ "$size" -gt "1000" ];then
#find 对应目录 -mtime +天数 -type f -name "文件名" -exec rm -rf {} \;
find ${log_path} -mtime +$DAYS -type f -name "*.log" -exec rm -rf {} \;
fi
#下面是任务计划
[[email protected] ~]# cat /var/spool/cron/root
SHELL=/bin/bash
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
export $PATH
0 0 * * * /bin/sh /opt/log_backup.sh
#赋予权限
chmod +x /opt/log_backup.sh
以上是关于Nginx脚本方式切割日志的主要内容,如果未能解决你的问题,请参考以下文章