天天看点

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

#下面是任务计划

[root@centos7 ~]# 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

本文转自  一招拜师  51CTO博客,原文链接:http://blog.51cto.com/sadoc/1933539

继续阅读