nginx日志管理

 

1) 创建日志目录

nginx 的默认日志目录所在硬盘空间可能比较小,所以根据硬盘的空间状况创建日志目录

比如:mkdir /backup/nginx_logs

 

2 )修改 nginx 配置文件

配置 nginx 的日志目录,指向你刚创建的目录

 

在配置文件中写:

根据时间情况写在 server 或者 http 或者 location , 本例写在 server

access_log /backup/nginx_logs/access.log combined;

 

上面的combined为 nginx 的默认日志格式,如果不这么写就需要重新定义,

本例中直接写了combined,这种格式 awstats 也认

 

3 )使用 logrotate 管理

logrotate 系统自带,并且会自动定时在凌晨 4 02 份启动

 

配置文件如下:

  1. /backup/nginx_logs { 
  2. daily 
  3. missingok 
  4. rotate 7
  5. nocompress 
  6. prerotate 
  7. /usr/local/awstats/wwwroot/cgi-bin/awstats.pl -update -config=yoursite.com
  8. endscript
  9. postrotate 
  10. if  [ -f /usr/local/nginx/logs/nginx.pid ];  then  
  11. kill -USR1 `cat /usr/local/nginx/logs/nginx.pid` 
  12. fi
  13. endscript 
  14. }

每次 rotate 之前,会先调用 awstats 产生统计数据, rotate 之后会给 nginx 发信号将日志写人新的空白日志文件

 

logrotate 会用到/etc/logrotate.conf配置文件和/etc/logrotate.d中所有的配置文件,所以无需改动 logrotate 配置,只需往/etc/logrotate.d加入上面的配置文件即可

 

写配置文件必须小心,否则 debug 很麻烦 , 比如你把配置文件中的nocompress去掉,以为会默认使用/etc/logrotate.conf中的 compress, 实际上不是这样的,如果/etc/logrotate.d中的配置文件错误, logrotate 不会用/etc/logrotate.conf替代,而且 /var/log/messages 和系统的发的 mail 中毫无出错信息,除非配置文件有明显的错误,才会 /var/log/messages 和系统的发的 mail 反应出来,郁闷

你可能感兴趣的:(nginx,server,Access)