nginx日志轮转是借助配置文件里的logrotate模块来完成的。该模块会周期性地检测日志文件的尺寸,一旦达到设定的阈值,就会自动把老的日志文件重新命名,并生成一个全新的空白日志文件以持续记录新产生的日志。这种方式能够避免日志文件体积过大,节省磁盘空间。
下面就是Nginx日志轮转的主要运作机制:
-
配置文件:首要的是,在Nginx的配置文档里要标明日志文件的位置以及轮转规则。这些信息一般存在于/etc/nginx/nginx.conf或者/etc/nginx/conf.d/目录下的某份配置文件内。
-
日志文件位置:在配置文件中,需确定访问日志(access log)和错误日志(Error log)的具体位置。例如:
Access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log;
-
轮转规则:随后,要设置日志轮转的具体方案。这通常是经由logrotate工具达成的,它会在/etc/logrotate.d/目录里寻找对应的配置文档。以下是一份简易的Nginx日志轮转配置实例:
/var/log/nginx/*.log { daily missingok rotate 7 compress notifempty create 0640 nginx adm }
此配置的含义如下:
- daily:每日执行一次日志轮转。
- missingok:若日志文件缺失,不会产生错误提示。
- rotate 7:保存最近七天的日志文件。
- compress:对旧日志文件进行压缩。
- notifempty:若日志文件为空,则不执行轮转。
- create 0640 nginx adm:新建日志文件时,权限设为0640,所有者为nginx,所属组为adm。
-
定时任务:logrotate工具一般会在系统启动时自动运行,并依据配置文档中的规定周期性地检查日志文件。另外,也可以通过cron定时任务手动触发日志轮转。
-
日志文件重命名与压缩:当满足轮转条件时,logrotate会将旧的日志文件改名为附带日期后缀的新文件名(如:access.log.1),并新建一个空的日志文件。同时,如果开启了压缩功能,还会将旧的日志文件压缩成.gz格式。
-
清除旧日志:按照配置文件里的rotate参数,logrotate会移除超出指定天数的旧日志文件。
通过上述流程,Nginx日志轮转能高效地管控日志文件的规模和数目,防止磁盘空间因过多的日志文件而被占用。