nginx日志分割原生方法
nginx的访问日志access.log随着访问量的增加会越来越大,不利于存储和分析,因此一般会对其进行分割。最常见的是按天分割,每天一个日志文件。
通常日志分割方法是用shell脚本+crontab定时任务,每天凌晨定时给日志文件重新命名,这种方法虽然有效,但有点麻烦。其实nginx自身是支持日志文件的重新命名的,通过直接修改nginx的配置文件 nginx.conf就可以达到同样的效果,所以称为nginx原生方法。具体方法参见https://blog.csdn.net/molaifeng/article/details/82667158,修改的脚本如下:
/etc/nginx/nginx.conf
if ($time_iso8601 ~ "(\d{4})-(\d{2})-(\d{2})") {
set $time $1$2$3;
}
#access_log /var/myweb/logs/access.log;
access_log /var/myweb/logs/access_${time}.log;
修改完以后执行
nginx -s reload
让配置文件生效。
按以上方法操作过程中发现两个问题,现象和解决方案如下:
问题1:if 语句的位置不对
现象
nginx.conf中,日志文件的默认配置放在 http 段落中,如果把以上代码放到这个位置ÿ