系统城装机大师 - 固镇县祥瑞电脑科技销售部宣传站!

当前位置:首页 > 数据库 > Access > 详细页面

nginx服务器中access_log日志分析与配置详解

时间:2019-12-04来源:系统城作者:电脑系统城

通过访问日志,可以知晓用户的地址,网站的哪些部分最受欢迎,用户的浏览时间,对大多数用户用的的浏览器做出针对性优化。下面这篇文章主要给大家介绍了关于nginx服务器中access_log日志分析与配置的相关资料,需要的朋友可以参考下。

前言

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

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

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

log_format 日志格式语法:

log_format name(格式名字) 格式样式(即想要得到什么样的日志内容)

示例:


 
  1. log_format main
  2. '$remote_addr - $remote_user [$time_local] "$request" '
  3. '$status $body_bytes_s ent "$http_referer" '
  4. '"$http_user_agent" "$http_x_forwarded_for"'

错误日志的形式如下:


 
  1. 201.158.69.116 - - [03/Jan/2013:21:17:20 -0600] fwf[-] tip[-] 127.0.0.1:9000 0.007 0.007MX pythontab.com GET /html/test.html HTTP/1.1 "200" 2426 "http://a.com" "es-ES,es;q=0.8" "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.97 Safari/537.11"
  2. 187.171.69.177 - - [03/Jan/2013:21:17:20 -0600] fwf[-] tip[-] 127.0.0.1:9000 0.006 0.006MX pythontab.com GET /html/test2.html HTTP/1.1 "200" 2426 "http://a.com" "es-ES,es;q=0.8" "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.97 Safari/537.11"

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

      1.客户端(用户)IP地址。如:上例中的 201.158.69.116

      2.访问时间。如:上例中的 [03/Jan/2013:21:17:20 -0600]

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

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

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

      6.用户地理位置代码(国家代码)。如:上例中的 MX(墨西哥)

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

      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格式设置:


 
  1. #access日志格式配置,具体参数不再细说,上面都已经说过了,自己对应一下即可
  2. log_format main '$remote_addr - $remote_user [$time_local] '
  3. 'fwf[$http_x_forwarded_for] tip[$http_true_client_ip] '
  4. '$upstream_addr $upstream_response_time $request_time '
  5. '$geoip_country_code '
  6. '$http_host $request '
  7. '"$status" $body_bytes_sent "$http_referer" '
  8. '"$http_accept_language" "$http_user_agent" ';
  9. #配置access log日志的存储位置及文件,注意:access.log文件是可以按日期进行分割的,方便查看及处理
  10. access_log /home/serversoft/nginx/log/access.log main;

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

分享到:

相关信息

  • 让Apache 2支持.htaccess并实现目录加密的方法

    让Apache 2支持.htaccess并实现目录加密的方法,这篇文章主要介绍了让Apache 2支持.htaccess并实现目录加密的方法,文中给出了详细的方法步骤,并给出了示例代码,对大家具有一定的参考价值,...

    2019-12-04

  • 使用.htaccess设置图片防盗链的详细方法

    对于虚拟主机用户来说,最方便的莫过于利用.htaccess设置图片防盗链了。上网搜了一下,.htaccess规则写法很多,但是大部分的区别在于最后一行,下面我们先看看正确的.htaccess防盗链写法,稍后我再详细解释一下最后一行的重点...

    2019-12-04

系统教程栏目

栏目热门教程

人气教程排行

站长推荐

热门系统下载