zoukankan      html  css  js  c++  java
  • Nginx访问日志(access_log)配置

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

    log_format #用来定义记录日志的格式(可以定义多种日志格式,取不同名字即可)

    access_log #用来指定日至文件的路径及使用的何种日志格式记录日志

    lof_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>    <Strin­­­g>;
    
        关键字         格式标签   日志格式
    
        关键字:其中关键字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]] [if=condition]];
        access_log path format gzip[=level] [buffer=size] [flush=time] [if=condition];
        access_log syslog:server=address[,parameter=value] [format [if=condition]];
    
        说明:
        buffer=size  #为存放访问日志的缓冲区大小
        flush=time  #为缓冲区的日志刷到磁盘的时间
        gzip[=level]  #表示压缩级别
        [if = condition]  #表示其他条件
    

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

    lof_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.wl.com permanent;
        }
        include vhost/*.conf;
    }
    

    (2)插入access_log语句

    server {
            access_log /data/log/www;
            listen 80;
            server_name abc.com www.wl.com;
    
            location / {
                    root /data/www/www;
                    index index.html index.htm;
            }
            error_log    logs/error_www.wl.com.log    error;
            access_log    logs/access_www.wl.com.log    main;
            #新增内容↑
    
    }
    

    (3)重启服务

    nginx -t
    nginx -s reload
    
  • 相关阅读:
    Java实现 蓝桥杯 历届试题 小计算器
    事实证明,应用市场是个流量的生意(产品能力并不足以形成护城河)
    迅雷创始人程浩:创业公司5招做好内部创新(组建小型敢死队:一共3个人,一个产品经理,两个研发;腾讯做不做这个项目是一个伪命题;让用户来验证,而不是相反 good)
    核心思想:创业者要做正确的决定,而非容易的决定(享受创业路上的孤单,你必须要有将自己关在小屋子里独自做重大且艰难决定的勇气)
    Delphi能通过SSH登录Linux,连接MYSQL取数么?像Navicat一样
    Qt5.7中使用MySQL Driver(需要把libmysql.dll文件拷贝到Qt的bin目录中。或者自己编译的时候,链接静态库)
    c++对象内存布局的理解
    观察者模式
    本地事务和分布式事务工作
    弱引用
  • 原文地址:https://www.cnblogs.com/xuyuQAQ/p/8728773.html
Copyright © 2011-2022 走看看