• 售前

  • 售后

热门帖子
入门百科

详解NGINX如何统计网站的PV、UV、独立IP

[复制链接]
塔米酉 显示全部楼层 发表于 2021-10-26 12:25:55 |阅读模式 打印 上一主题 下一主题
Nginx: PV、UV、独立IP

做网站的都知道,寻常经常要查询下网站PV、UV等网站的访问数据,当然假如网站做了CDN的话,nginx本地的日志就没什么意义了,下面就对nginx网站的日志访问数据做下统计;

概念:
      
  • UV(Unique Visitor):独立访客,将每个独立上网电脑(以cookie为依据)视为一位访客,一天之内(00:00-24:00),访问您网站的访客数量。一天之内类似cookie的访问只被盘算1次  
  • PV(Page View):访问量,即页面浏览量大概点击量,用户每次对网站的访问均被纪录1次。用户对同一页面的多次访问,访问量值累计  
  • 统计独立IP:00:00-24:00内类似IP地点只被盘算一次,做网站优化的朋侪最关心这个
先声明下环境,此次运行的nginx版本1.7,后端Tomcat运行的是动态交互步调(需进行用户认证,假如是静态页面则抓不到cache值,$http_cookie是空值),就是这样;

nginx日志文件设置
  1. http {
  2.   include    mime.types;
  3.   default_type application/octet-stream;
  4.   log_format main '$remote_addr - [$time_local] "$request" '
  5.             ' - $status "User_Cookie:$guid" ';
  6. #User_Cookie为日志显示字符,$guid为变量,具体内容在下面定义,也可在日志格式里写入$http_cookie 显示完整的cookie内容<br>
  7.   sendfile    on;
  8.   keepalive_timeout 65;
  9.     upstream backserver {
  10.     ip_hash;
  11.     server 1.1.2.2:8080;
  12.     server 1.1.2.3:8080;
  13. }
  14. server {
  15.     listen    80;
  16.     server_name localhost;
  17.     #if ( $http_cookie ~* "(.*)$") 匹配所有内容
  18.     if ( $http_cookie ~* "CSID=([A-Z0-9]*)"){
  19.         set $guid $1;
  20.     }  #只匹配CSID字符信息,此处为正则表达式<br>
  21.     access_log logs/host.access.log main;
  22.      location ~* ^(.*)$ {
  23.        #limit_req zone=allips burst=1 nodelay;
  24.        proxy_pass http://backserver;
  25.        proxy_set_header Host $host;
  26.        proxy_set_header X-Real-IP $remote_addr;
  27.        proxy_set_header REMOTE-HOST $remote_addr;
  28.        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  29.        client_max_body_size 8m;
  30.        }
  31.     error_page  500 502 503 504 /50x.html;
  32.     location = /50x.html {
  33.       root  html;
  34.     }
  35. }
复制代码
注:$http_cookie这个内里的值是一个一个cookie的值,中心以“;”分隔

日志输特殊式
  1. 192.168.40.2 - [02/Nov/2016:15:44:35 +0800]  "GET /wcm/app/main/refresh.jsp?r=1478072325778 HTTP/1.1"  - 200 "User_Cookie:7F00000122A5597C46607B1C0A7EC016"
  2. 192.168.40.2 - [02/Nov/2016:15:44:35 +0800]  "GET /webpic/W0201611/W020161102/W020161102566715167404.jpg HTTP/1.1"  - 200 "User_Cookie:7F00000122A5597C46607B1C0A7EC016"
  3. 119.255.31.109 - [02/Nov/2016:15:44:36 +0800]  "GET /wcm/app/main/refresh.jsp?r=1478072510132 HTTP/1.1"  - 200 "User_Cookie:7F000001237921BE9237838AEC65704D"
  4. 119.255.31.109 - [02/Nov/2016:15:44:36 +0800]  "GET /wcm/app/message/message_query_service.jsp?READFLAG=0&MSGTYPES=1%2C2%2C3 HTTP/1.1"  - 200 "User_Cookie:7F000001237921BE9237838AEC65704D"
  5. 192.168.40.2 - [02/Nov/2016:15:44:37 +0800]  "GET /wcm/app/message/message_query_service.jsp?READFLAG=0&MSGTYPES=1%2C2%2C3 HTTP/1.1"  - 200 "User_Cookie:7F00000123D3BF2345115EAAC21F71E0"
  6. 192.168.40.2 - [02/Nov/2016:15:44:37 +0800]  "GET /wcm/app/message/message_query_service.jsp?READFLAG=0&MSGTYPES=1%2C2%2C3 HTTP/1.1"  - 200 "User_Cookie:7F00000123EF73896DF98EDA9950944E"
  7. 192.168.40.2 - [02/Nov/2016:15:44:37 +0800]  "GET /wcm/app/message/message_query_service.jsp?READFLAG=0&MSGTYPES=1%2C2%2C3 HTTP/1.1"  - 200 "User_Cookie:7F00000123FE0F9C397E1A8F0C4F044B"
  8. 192.168.40.2 - [02/Nov/2016:15:44:37 +0800]  "GET /wcm/app/main/refresh.jsp?r=1478072511427 HTTP/1.1"  - 200 "User_Cookie:7F00000123A465B7EA1DE0AF0AE671B7"
  9. 119.255.31.109 - [02/Nov/2016:15:44:38 +0800]  "GET /wcm/app/message/message_query_service.jsp?READFLAG=0&MSGTYPES=1%2C2%2C3 HTTP/1.1"  - 200 "User_Cookie:7F00000123D89B11302DF80AE773C900" 
复制代码
PV统计

可统计单个链接地点访问量:
  1. [root@localhost logs]# grep index.shtml host.access.log | wc -l
复制代码
总PV量:
  1. [root@localhost logs]# awk '{print $6}' host.access.log | wc -l
复制代码
独立IP
  1. [root@localhost logs]# awk '{print $1}' host.access.log | sort -r |uniq -c | wc -l
复制代码
UV统计
  1. [root@localhost logs]# awk '{print $10}' host.access.log | sort -r |uniq -c |wc -l
复制代码
Cookie 测试页面

关于种cookie,可以利用下面的html代码,编辑,添加需要种的cookie
  1. #index.html
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml">
  4. <head>
  5. <meta http-equiv="Content-Type" content="text/html; charset=gbk">
  6. <meta http-equiv="Refresh" content="10"> //为了方便测试,每10秒刷新一次页面
  7. </head>
  8. <body>
  9. <h1>test.test.com域测试</h1>
  10. 下面列出了该域的cookie<br>
  11. <p>
  12. <script>
  13. document.cookie="guid=A1UD8E5512451111111111"; //种cookie,追加
  14. document.cookie="city=beijing"; //种cookie,追加
  15. document.write(document.cookie); //列出已经存在的
  16. </script>
  17. </p>
  18. </body>
  19. </html>
复制代码
以上就是本文的全部内容,希望对各人的学习有所帮助,也希望各人多多支持脚本之家。

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作