十二周三次课 (4月25日) 12.10 Nginx访问日志 12.11 Nginx日志切割 12.12 静态文件不记录日志和过期时间

Nginx访问日志

日志格式 vim /usr/local/nginx/conf/nginx.conf //搜索log_format 除了在主配置文件nginx.conf里定义日志格式外,还需要在虚拟主机配置文件中增加 access_log /tmp/1.log combined_realip; 这里的combined_realip就是在nginx.conf中定义的日志格式名字 -t && -s reload curl -x127.0.0.1:80 test.com -I cat /tmp/1.log

[root@izbp1iei7rfo61naj23hlez vhost]# cat /tmp/1.log 127.0.0.1 - [25/Apr/2018:22:03:28 +0800] test3.com "/index.html" 301 "-" "curl/7.29.0" 127.0.0.1 - [25/Apr/2018:22:03:50 +0800] test.com "/index.html" 200 "-" "curl/7.29.0"

Nginx日志切割

自定义shell 脚本 vim /usr/local/sbin/nginx_log_rotate.sh//写入如下内容

#! /bin/bash
#假设nginx的日志存放路径为/tmp/
d=`date -d "-1 day" +%Y%m%d` 
logdir="/tmp/"
nginx_pid="/usr/local/nginx/logs/nginx.pid"
cd $logdir
for log in `ls *.log`
do
mv $log $log-$d
done
/bin/kill -HUP `cat $nginx_pid`

执行任务

[root@izbp1iei7rfo61naj23hlez vhost]# sh -x /usr/local/sbin/nginx_log_rotate.sh ++ date -d '-1 day' +%Y%m%d

  • d=20180424
  • logdir=/tmp/
  • nginx_pid=/usr/local/nginx/logs/nginx.pid
  • cd /tmp/ ++ ls 1.log
  • for log in 'ls *.log'
  • mv 1.log 1.log-20180424 ++ cat /usr/local/nginx/logs/nginx.pid
  • /bin/kill -HUP 13116

任务计划crontab -e 0 0 * * * /bin/bash /usr/local/sbin/nginx_log_rotate.sh

静态文件不记录日志和过期时间

vi /usr/local/nginx/conf/vhost/test.com.conf 配置如下

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
    {
          expires      7d;
          access_log off;
    }
location ~ .*\.(js|css)$
    {
          expires      12h;
          access_log off;
    }

此处为定义某些时间和记录某些日志