• nginx 日志分割


    nginx的log日志分为access log 和 error log  

    设置在nginx.conf 文件中,默认日志:

    其中access log 记录了哪些用户,哪些页面以及用户浏览器、ip和其他的访问信息

    error log 则是记录服务器错误日志

    access log的形式如下:

    10.1.1.1 - - [22/Aug/2014:16:48:14 +0800] "POST /ajax/MbpRequest.do HTTP/1.1" 200 367 "-" "Dalvik/1.6.0 (Linux; U; Android 4.1.1; ARMM7K Build/JRO03H)" "119.189.56.175" 127.0.0.1:8090 0.022 0.022 

    从上面我们可以看出几部分信息:

    1.客户端(用户)IP地址。如:上例中的 10.1.1.1 (内网负载均衡地址)

    2.访问时间。如:上例中的 [22/Aug/2014:16:48:19 +0800]

    3.访问端口。如:上例中的 127.0.0.1:8080

    4.响应时间。如:上例中的 0.022

    5.请求时间。如:上例中的 0.022

    6.用户地理位置代码(国家代码)。

    7.请求的url地址(目标url地址)的host。如:上例中的 /....

    8.请求方式(GET或者POST等)。如:上例中的 GET

    9.请求url地址(去除host部分)。如:上例中的 /html/test.html

    10.请求状态(状态码,200表示成功,404表示页面不存在,301表示永久重定向等,具体状态码可以在网上找相关文章,不再赘述)。如:上例中的 "200"

    11.请求页面大小,默认为B(byte)。如:上例中的 2426

    12.来源页面,即从哪个页面转到本页,专业名称叫做“referer”。如:上例中的 "http://a.com"

    13.用户浏览器语言。如:上例中的 "es-ES,es;q=0.8"

    14. 用户浏览器其他信息,浏览器版本、浏览器类型等。如:上例中的  "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.97 Safari/537.11"

    其实nginx access日志的格式不是一成不变的,是可以自定义的。

    在nginx的nginx.conf配置文件找到:log_format 这里就是日志的格式

    看一下和上述日志匹配的log格式设置:

    #access日志格式配置,具体参数不再细说,上面都已经说过了,自己对应一下即可

     log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                          '$status $body_bytes_sent "$http_referer" '
                          '"$http_user_agent" "$http_x_forwarded_for"'
                           '$upstream_addr $upstream_response_time $request_time ';
        access_log  logs/access.log  main;

    如果nginx位于负载均衡器,squid,nginx反向代理之后,web服务器无法直接获取到客户端真实的IP地址了。 $remote_addr获取反向代理的IP地址。反向代理服务器在转发请求的http头信息中,可以增加X-Forwarded-For信息,用来记录 客户端IP地址和客户端请求的服务器地址:

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

    相关说明解释

    1. $remote_addr, $http_x_forwarded_for 记录客户端IP地址
    2. $remote_user 记录客户端用户名称
    3. $request 记录请求的URLHTTP协议
    4. $status 记录请求状态
    5. $body_bytes_sent 发送给客户端的字节数,不包括响应头的大小; 该变量与Apache模块mod_log_config里的“%B”参数兼容。
    6. $bytes_sent 发送给客户端的总字节数。
    7. $connection 连接的序列号。
    8. $connection_requests 当前通过一个连接获得的请求数量。
    9. $msec 日志写入时间。单位为秒,精度是毫秒。
    10. $pipe 如果请求是通过HTTP流水线(pipelined)发送,pipe值为“p”,否则为“.”。
    11. $http_referer 记录从哪个页面链接访问过来的
    12. $http_user_agent 记录客户端浏览器相关信息
    13. $request_length 请求的长度(包括请求行,请求头和请求正文)。
    14. $request_time 请求处理时间,单位为秒,精度毫秒; 从读入客户端的第一个字节开始,直到把最后一个字符发送给客户端后进行日志写入为止。
    15. $time_iso8601 ISO8601标准格式下的本地时间。
    16. $time_local 通用日志格式下的本地时间。

    查看日志命令tail -100f /usr/local/software/nginx/logs/access.log

            tail命令查看:  http://man.linuxde.net/tail

    nginx日志自动分割

      配置shell脚本

    1 #!/bin/bash
    2 # 设置日志文件存放目录
    3 logs_path="/var/logs/nginx/"
    4 # 设置pid文件
    5 pid_path="/usr/local/dev/nginx/nginx.pid"
    6 # 重命名日志文件
    7 mv ${logs_path}access.log ${logs_path}access_$(date -d "yesterday" +"%Y%m%d").log
    8 # 向nginx主进程发信号重新打开日志
    9 kill -USR1 `cat ${pid_path}`

      crontab中设置定时 

    进行编辑

    crontab -e

    配置内容如下

    0 0 * * * bash /usr/local/dev/nginx/nginx_log.sh

    这样在每天的夜晚12点就会自动创建备份文件了。

  • 相关阅读:
    CodeForces 492C Vanya and Exams (贪心)
    CodeForces 492A Vanya and Cubes
    如何设置 Windows 默认命令行窗口大小和缓冲区大小
    [MySQL] Data too long for column 'title' at row 1
    [转] Hibernate不能自动建表解决办法(hibernate.hbm2ddl.auto) (tables doesn't exist)
    CodeForces 489D Unbearable Controversy of Being (不知咋分类 思维题吧)
    Autofac官方文档翻译--二、解析服务--1解析参数传递
    Autofac官方文档翻译--一、注册组件--4组件扫描
    Autofac官方文档翻译--一、注册组件--3属性和方法注入
    Autofac官方文档翻译--一、注册组件--2传递注册参数
  • 原文地址:https://www.cnblogs.com/xuey/p/8579906.html
Copyright © 2020-2023  润新知