一.使用脚本切割
编辑脚本
tianshl@tianshl nginx $ vim nginx_log_division.sh
脚本内容
#! /bin/sh
yesterday=`date -v -1d +%Y%m%d`
log_path="/usr/local/var/log/nginx/"
sdk_path=${log_path}sdk
mv -f ${sdk_path}.log ${sdk_path}_${yesterday}.log
pid_path="/usr/local/var/run/nginx.pid"
sudo kill -USR1 `cat ${pid_path}`
定时任务
切换到root身份
tianshl@tianshl nginx $ sudo su root
编辑 crontab
sh-3.2
crontab 添加一行
0 0 * * * sh /usr/local/var/log/nginx/nginx_log_division.sh
查看是否添加成功
sh-3.2
二.不使用脚本切割
server 段增加以下代码
if ($time_iso8601 ~ "(\d{4})-(\d{2})-(\d{2})") {
set $time $1$2$3;
}
日志文件路径中增加日期参数
access_log /var/log/nginx/api-$time.log;
举个栗子
events {
worker_connections 1024;
}
http {
server {
listen 88;
if ($time_iso8601 ~ "(\d{4})-(\d{2})-(\d{2})") {
set $time $1$2$3;
}
location /sdk {
access_log /usr/local/var/log/nginx/sdk-$time.log;
proxy_pass http://localhost:8888;
}
}
}
栗子描述
1. 访问/sdk时会生成当天时间的日志文件,当文件存在时则追加内容,文件不存在时自动创建。
2. 同理可以按年、月、日、小时、分钟、秒等进行切分。