Nginx日志切割

来源:互联网 发布:国外聊天软件app 编辑:程序博客网 时间:2024/06/05 09:14

一.使用脚本切割

编辑脚本
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日志路径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 -e
crontab 添加一行
0 0 * * * sh /usr/local/var/log/nginx/nginx_log_division.sh
查看是否添加成功
sh-3.2# crontab -l

二.不使用脚本切割

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 {        # 监听88端口        listen 88;        if ($time_iso8601 ~ "(\d{4})-(\d{2})-(\d{2})") {            set $time $1$2$3;        }        location /sdk {            # 输出sdk访问日志            access_log /usr/local/var/log/nginx/sdk-$time.log;            proxy_pass http://localhost:8888;        }    }}
栗子描述
1. 访问/sdk时会生成当天时间的日志文件,当文件存在时则追加内容,文件不存在时自动创建。2. 同理可以按年、月、日、小时、分钟、秒等进行切分。
原创粉丝点击