Nginx日志切割

转载自:Nginx日志切割(按天切割) - Xiao涛 - 博客园 

Nginx日志切割(按天切割)

先确定nginx日志路径和pid路径

我的Nginx日志路径在:/var/log/nginx/(access,error).log

我的PID路径在:/run/nginx.pid

一、创建日志切割后的存放路径  

mkdir -p /var/log/nginx/logs

二、编写脚本文件,存放在任何路径都可

vi runlog.sh

#!/bin/bash

# 设置日志文件存放目录
logs_path="/var/log/nginx/"
backup_path="/var/log/nginx/logs/"
# 设置pid文件
pid_path="/run/nginx.pid"

# 重命名日志文件
mv ${logs_path}/access.log ${backup_path}/access_$(date -d "yesterday" +"%Y%m%d").log
mv ${logs_path}/error.log ${backup_path}/error_$(date -d "yesterday" +"%Y%m%d").log

# 向nginx主进程发信号重新打开日志
kill -USR1 `cat ${pid_path}`

# 压缩
gzip ${backup_path}/access_$(date -d "yesterday" +"%Y%m%d").log
gzip ${backup_path}/error_$(date -d "yesterday" +"%Y%m%d").log

# 删除超过指定时间的日志文件,单位:天
find  $backup_path -name "*.gz" -type f -mtime +30 -exec rm -rf {} \;

注意,kill -USR1 `cat ${pid_path}` 

简单说明一下:

1、在没有执行kill -USR1 `cat ${pid_path}`之前,即便已经对文件执行了mv命令也只是改变了文件的名称,nginx还是会向新命名的文件【access_$(date -d "yesterday" +"%Y%m%d").log / error_$(date -d "yesterday" +"%Y%m%d").log】中照常写入日志数据。原因在于linux系统中,内核是根据文件描述符来找文件的

2、USR1是自定义信号,也就是进程编写者自己确定收到这个信号该干什么。而在nginx中它自己编写了代码当接到USR1信号的时候让nginx重新打开日志文件(重新打开的日志就是配置文件中设置的位置和名称)

三、编写定时任务

crontab -e
0 0 * * * sh /var/log/nginx/runlog.sh

你可能感兴趣的:(Linux,nginx,运维)