开发者社区> 技术小胖子> 正文

Discuz在线人数统计原理-个人分析

简介:
+关注继续查看


Discuz在线人数统计原理-个人分析

 

eluban论坛在线人数统计原理

2013-5-6

一、基本原理(流程)

 

 

1、读取和生成在线人数

用户每次进入首页,会读取COOKIE中的$_DCOOKIE['onlineusernum'](在线人数cookie值,此cookie包括会员和游客)。

[a]、如果【有】,这个值就去取,然后直接显示。

[b]、如果【没有】,系统就会分别统计表cdb_sessions中“会员(已登录)”和“游客(没有登录)”的人数。并创建$_DCOOKIE['onlineusernum']注意:此cookie时间只有5分钟。如果过了5分钟,用户再次进入首页,则需要重新到数据库获取并重新创建cookie。五分钟时间刚好,DZ这种做法可以有效的缓解服务器的压力。

 

会员在cdb_sessions表中会记录用户的IPusernameuid

游客在cdb_sessions表的usernameuid为空,仅记录IP,以此来区分。

 

[c]、另外论坛在线人数统计还受“在线保持时间”控制,如图:

 

“在线保持时间”是指:用户过了这个设定的值没有活动,然后其他任何一用户任一操作都会使系统自动将表cdb_sessions中此用户的数据删除。注意:只是删除此用户在首页显示的在线状态,不是已退出网站(即此用户还是登录状态)。

 

2、更新用户状态

用户每刷新一次页面(包括打开任何一个新页面),系统都会修改表cdb_sessions中的lastactivity(最后活动时间)字段和action(当前操作代号)等。比如:会员是根据usernameuid进行修改。游客是根据IP进行修改。

 

3、用户退出处理

用户点击“退出”,系统会删除cdb_sessions中此账号对应的sessions信息。

注意:直接关闭浏览器、直接清除浏览器cookie或长时间没有操作页面。cdb_sessions表中这些用户会根据“在线保持时间”来处理。

如果当前时间  最后活动时间lastactivity >在线保持时间,系统自动删除cdb_sessions表中此用户数据。

如果当前时间  最后活动时间lastactivity <=在线保持时间,

cdb_sessions表中如果【有】此用户信息就修改此用户的最后活动时间lastactivity

cdb_sessions表中如果【没有】此用户信息就添加一条此用户认证信息。

 

二、数据库

数据库类有专门的一张表记录当前在线用户的登录状态(表:cdb_sessions

 

 

各字段释义如下:

cdb_sessions    会员认证表

sid    char    SID

ip1    tinyint    IP

ip2    tinyint    IP

ip3    tinyint    IP

ip4    tinyint    IP

uid    mediumint    会员ID

username    char    会员名

groupid    smallint    会员组

styleid    smallint    风格ID

invisible    tinyint    是否隐身登录

action    tinyint    当前动作

lastactivity    int    最后活动时间

lastolupdate    int    最后更新时间

pageviews    smallint    页面访问量

seccode    smallint    记录验证码

fid    smallint    论坛ID

tid    mediumint    主题ID

bloguid    mediumint    正在浏览的文集

 

三、代码

1、  控制处理代码(根目录index.php220行左右)

 


  1. <?php 
  2.         if(empty($_DCOOKIE['onlineusernum'])) { 
  3.             $onlinenum = $db->result_first("SELECT COUNT(*) FROM {$tablepre}sessions"); 
  4.             if($onlinenum > $onlineinfo[0]) { 
  5.                 $_DCACHE['settings']['onlinerecord'] = $onlinerecord = "$onlinenum\t$timestamp"
  6.                 $db->query("UPDATE {$tablepre}settings SET value='$onlinerecord' WHERE variable='onlinerecord'"); 
  7.                 require_once DISCUZ_ROOT.'./include/cache.func.php'
  8.                 updatesettings(); 
  9.                 $onlineinfo = array($onlinenum$timestamp); 
  10.             } 
  11.             dsetcookie('onlineusernum'intval($onlinenum), 300); 
  12.         } else { 
  13.             $onlinenum = intval($_DCOOKIE['onlineusernum']); 
  14.         } 
  15.         $onlineinfo[1] = gmdate($dateformat$onlineinfo[1] + ($timeoffset * 3600)); 
  16.  
  17. ?> 

2、  模板循环显示代码(模板根目录discuz.htm290行左右)

 


  1. <ul class="userlist"> 
  2. <!--{if $whosonline}--> 
  3.     <!--{loop $whosonline $key $online}--> 
  4.         <li title="{lang time}: $online[lastactivity]{LF} {lang action}: $online[action] <!--{if $online['fid']}-->{LF}{lang forum}: $online[fid]<!--{/if}-->"> 
  5.         <img src="images/common/$online[icon]" alt="" /> 
  6.         <!--{if $online['uid']}--> 
  7.             <a href="space.php?uid=$online[uid]">$online[username]</a> 
  8.         <!--{else}--> 
  9.             $online[username] 
  10.         <!--{/if}--> 
  11.         </li> 
  12.     <!--{/loop}--> 
  13. <!--{else}--> 
  14.     <li style="width: auto">{lang online_only_guests}</li> 
  15. <!--{/if}--> 
  16. </ul> 

 

 




      本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/1194265,如需转载请自行联系原作者






版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
网站流量日志分析--统计分析--回头单次访客分析|学习笔记
快速学习网站流量日志分析--统计分析--回头单次访客分析
19 0
网站流量日志分析--统计分析--新老访客实现(join 语句)|学习笔记
快速学习网站流量日志分析--统计分析--新老访客实现(join 语句)
88 0
【最佳实践】页面浏览量统计的绝佳实现
【最佳实践】页面浏览量统计的绝佳实现
227 0
WordPress网站怎时统计在线人数
如果需要在前台显示网站实时在线人数,可以使用whos.amung.us提供的一款在线人数实时统计工具,它可以统计你的网站或者博客当前在线人数,支持自定义颜色。
49 0
【JavaWeb】案例 1:记录网站的登录成功人数
本期主要介绍案例 1:记录网站的登录成功人数
28 0
LeetCode(数据库)- 统计各专业学生人数
LeetCode(数据库)- 统计各专业学生人数
30 0
网站访问量统计小案例 | 学习笔记
快速学习网站访问量统计小案例。
156 0
30亿日志,检索+分页+后台展示,你是否遇到过更奇葩的需求?
一个数据库查询日志,前台页面显示的问题。
624 0
网站访问数据统计
网站访问数据统计
2448 0
文章
问答
文章排行榜
最热
最新
相关电子书
更多
《开放搜索查询分析服务架构分享》
立即下载
实时数据分析演示
立即下载
《实时数据分析演示)》
立即下载