Nginx访问日志(access_log)配置及信息详解

通过查看 Nginx 访问日志,就可以知晓用户的地址,浏览时间,网站的哪部分最受欢迎,这样就可以对大多数用户用的的浏览器做出针对性优化。

Nginx访问日志(access_log)介绍

Nginx 会把每个用户访问日志信息记录到指定的日志文件里,供网站管理员分析用户浏览行为等,此功能由 ngx_http_log_module 模块负责。

访问日志参数

Nginx访问日志主要有两个参数控制

log_format #用来定义记录日志的格式(可以定义多种日志格式,取不同名字即可)
access_log #用来指定日至文件的路径及使用的何种日志格式记录日志

log_format 的默认值:

# log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';

access_log 的默认值:

#access_log logs/access.log main;

log_format 语法格式及参数语法说明如下:

log_format <NAME> <String>;

关键字格式标签日志格式

  • 关键字:其中关键字 error_log 不能改变
  • 格式标签:格式标签是给一套日志格式设置一个独特的名字
  • 日志格式:给日志设置格式

log_format 格式变量:

$remote_addr #记录访问网站的客户端地址

$remote_user #远程客户端用户名

$time_local #记录访问时间与时区

$request #用户的http请求起始行信息

$status #http状态码,记录请求返回的状态码,例如:200、301、404等

$body_bytes_sent #服务器发送给客户端的响应body字节数

$http_referer #记录此次请求是从哪个连接访问过来的,可以根据该参数进行防盗链设置。

$http_user_agent #记录客户端访问信息,例如:浏览器、手机客户端等

$http_x_forwarded_for #当前端有代理服务器时,设置web节点记录客户端地址的配置,此参数生效的前提是代理服务器也要进行相关的x_forwarded_for设置

access_log 语法格式及参数语法说明如下:

access_log <FILE> <NAME>;
  • 关键字:其中关键字error_log不能改变
  • 日志文件:可以指定任意存放日志的目录
  • 格式标签:给日志文件套用指定的日志格式

其他语法:

access_log off; #关闭access_log,即不记录访问日志

access_log path format [buffer=size [flush=time]];access_log path format gzip=level flush=time;access_log syslog:server=address,parameter=value];

说明:

buffer=size #为存放访问日志的缓冲区大小

flush=time #为缓冲区的日志刷到磁盘的时间

gzip[=level] #表示压缩级别

[if = condition] #表示其他条件

一般场景这些参数都无需配置,极端优化才有可能会考虑这些参数。

log_format 参数的标签段位置:

http

access_log参数的标签段位置:

http, server, location, if in location, limit_except

参考资料:http://nginx.org/en/docs/http/ngx_http_log_module.html

Nginx配置访问日志过程介绍

  1. 创建log_format语句
worker_processes  1;
error_log logs/error.log error;
events {
    worker_connections  1024;
}
http {
    include status.conf;
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                               '$status $body_bytes_sent "$http_referer" '
                               '"$http_user_agent" "$http_x_forwarded_for"';
    access_log  logs/access.log  main;
    server {
        listen       80;
        server_name  localhost;
        rewrite ^/.* http://www.abc.com permanent;
    }
    include vhost/*.conf;
}
  1. 插入access_log语句
vi conf/vhost/www.abc.com.conf
#vi编辑虚拟主机配置文件
#文件内容:
server {
        access_log /data/log/www;
        listen 80;
        server_name abc.com www.abc.com;
        location / {
                root /data/www/www;
                index index.html index.htm;
        }
        error_log    logs/error_www.abc.com.log    error;
        access_log    logs/access_www.abc.com.log    main;
        #新增内容↑
}
  1. 重启服务

确认无误便可重启,操作如下:

nginx -t
#结果显示ok和success没问题便可重启
nginx -s reload
  1. 查看访问日志文件
ll 
logs/access_www.abc.com.log -rw-r--r-- 1 root root 2305 Jun 13 18:25

查看是否产生该文件,如果生成了该文件则表示配置成功。