Nginx日志切割

一.使用脚本切割

编辑脚本
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. 同理可以按年、月、日、小时、分钟、秒等进行切分。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值