您的位置:首页 > 运维架构 > Nginx

nginx日志切割

2017-10-23 16:06 260 查看
针对Linux 下 nginx日志全部写到一个文件中时,可以采用定时任务切割日志,这样很方便对日志管理,查看,储存

第一步、编写切割日志脚本(实质就是到固定时间的日志修改名字,并重新写nginx日志)

#!/bin/bash
#切割日志脚本,命名为 nginxLogSplit.sh.

#nginx日志位置
LOGS_PATH=/var/log/nginx
#昨天格式化时间
YESTERDAY=$(date -d "yesterday" +%Y-%m-%d)

#把访问日志改名字昨天格式化时间
mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log
#把错误日志改名字昨天格式化时间
mv ${LOGS_PATH}/error.log ${LOGS_PATH}/error_${YESTERDAY}.log

## 向 Nginx 主进程发送 USR1 信号。USR1 信号是重新打开日志文件(重点),不然会继续写进之前改过的日志文件里
kill -USR1 $(cat /var/log/nginx/nginx.pid)


第二步、设置定时任务

使用 命令
crontab -e


写入 脚本:

#零点时候切割日志


0 0 * * * /bin/bash /var/log/nginx/nginxLogRotate.sh


脚本格式解释下:

.---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  *  command to be executed


(可以在 /var/spool/cron 目录下看到刚刚写进的定时任务)

这样就全部ok了,第一次弄建议先设置一个临近的时间测试一下
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  nginx linux