多种方案实现PHP统计在线人数

  • 内容
  • 相关

首先介绍一下所涉及的数据表结构,四个字段:
代码如下:


uid<int(10)> :用户id

session_id<varchar(40)> :用户登录后系统产生的session_id,PHP可是使用session_id()函数获取

login_time<int(10)> :登录时间

logout_time<int(10)> :登出时间

1、客户端定时发送请求到服务器端。实现方法是在用户登录后,将uid,session_id,login_time插入一条记录,然后在客户端js设定一个计时器,比如每10分钟向服务器端发送一个请求,以此来达到更新登出时间的目的,当然这个间隔时间设定的越短,数据可能会越准确,不过相应的系统的负载也会越高,这个可以根据实际情况设定一个合适的值。这种方法广泛应用于webgame上,因为webgame的几乎所有请求都是ajax请求,不用刷新页面,一旦刷新页面,这个计时器就失去了价值,这也是这个方法的局限性。

    2、务器设定一个定时轮询的脚本。这个方法是在服务器端写一个定时执行的脚本,比如5分钟执行一次,根据数据库中的记录来判断每个会话的 session_id是否还存在于服务器上,如果存在就更新logout_time,不存在就跳过。这样也能比较准确的统计在线时间,不过缺点是需要有服务器的控制权,不然无法设定定时脚本,linux系统可以通过crontab实现,windows系统可以通过计划任务来完成。如果你只是买的虚拟主机,那么这个方法也同样不适合你。

    3、在用户每次活动时更新一下登出时间。这样在用户不活动或者退出的时候,登出时间就自然而 然的存在于数据库里了,这也是本文着重讨论的方案。下面给出实现方法。


代码如下:

$uid = $_SESSION[uid] = $info[id]; $session_id = $_SESSION[session_id] = session_id(); $login_time = time(); $logout_time = time() 600; $sql = "INSERT INTO member_login (uid,session_id,login_time,logout_time) values($uid, $session_id,$login_time,$logout_time)"; mysql_query($sql);

然后在用户每次活动,也就是每点击一个页面时,如果session存在也就是处于登录状态时,更新用户登出时间


代码如下:


if($_SESSION[uid]){ $uid = $_SESSION[uid]; $session_id = $_SESSION[session_id]; $logout_time = time() 600; $sql = "UPDATE member_login SET logout_time=$logout_time WHERE uid=$uid AND session_id=$session_id"; mysql_query($sql); }


这种方法的优点是相对来说实现起来比较简单,能够适用于大多数的网站,没有额外的服务器需求,而且也可以比较准确的统计用户的在线时间。

缺点也很明显,增加了数据库的更新操作,增加了系统的负载,不过对于中小型网站来说应该不是问题。

本文标签:

版权声明:若无特殊注明,本文皆为《鬼少》原创,转载请保留文章出处。

本文链接:多种方案实现PHP统计在线人数 - http://tv1314.com/post-108.html

发表评论

电子邮件地址不会被公开。 必填项已用*标注

评论

3条评论
  1. avatar

    Watish Lv.5 Chrome 52.0.2743.116 Chrome 52.0.2743.116 Windows Windows 回复

    为什么你的背景音乐都这么好听,好歌单分享下呗

    江苏省泰州市 电信

    1. Lv.1 Chrome 52.0.2743.116 Chrome 52.0.2743.116 Windows 7 Windows 7 回复

      音乐收藏不就能直达网易歌单么。

      广东省深圳市 电信

    2. Watish Lv.5 Chrome 52.0.2743.116 Chrome 52.0.2743.116 Windows Windows 回复

      一激动就忘了

      江苏省泰州市 电信

00:00 / 00:00
顺序播放