关于采集用户页面停留时长的一些思路

Posted 玩双截棍的熊猫

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于采集用户页面停留时长的一些思路相关的知识,希望对你有一定的参考价值。

关于  记录用户在页面停留时长的一些思路


客户端=====================================================================

(全部采用ajax后台发送数据)


进入页面时,开始计时,发送的数据为:
{id:"",type:"startTime",url="当前浏览的页面地址"}


响应的数据:
{code:"响应代码",msg="错误信息",id="当前记录的唯一编号"}


心跳计时,每隔几秒发送数据到接口:
{id:"当前记录的唯一编号",type:"heartBeat",url="当前浏览的页面地址"}
响应的数据:
{code:"响应代码",msg="错误信息",id="当前记录的唯一编号"}

 

 

服务端=====================================================================
1、根据请求的type判断发送的数据类型
  1.1、开始记录 startTime (请求的数据格式:{id:"",type:"startTime",url="当前浏览的页面地址"})
    1.1.1、获取当前日期已存储的记录总数,在redis中的key为 当前年月日_count(如:2017_08_01_count),如果没有就创建,默认值为0
(备注:当前时间为23点或23点以后,将记录为明天的,比如 2017年8月1日23:00 对应的key为 2017_08_02_count )
    1.1.2、创建记录唯一id (根据 当前年月日_已记录的总数+1 创建,如:2017_08_01_0 ),并将总数+1
    1.1.3、记录当前时间,并设置最后时间(endTime)为当前时间+3秒
    1.1.4、使用之前创建的id作为key,将数据写入redis(写入失败时将  总数-1)
    1.1.5、将处理的结果返回到客户端
       (响应的数据格式 {code:"",msg="",id=id} ,返回成功code=200,否则为失败,msg为错误信息,id为存入redis的key )


  1.2、心跳计时 heartBeat (请求的数据格式:{id:"2017_08_01_0",type:"startTime",url="当前浏览的页面地址"})
    1.2.1、查询redis中是否已存在请求中的key,如果不存在则以 startTime 进行处理
    1.2.2、修改key对应值的endTime为当前时间
    1.2.3、将处理的结果返回到客户端
       (响应的数据格式 {code:"",msg="",id=id} ,返回成功code=200,否则为失败,msg为错误信息,id为存入redis的key )





统计服务=====================================================================

定时任务,在每天的凌晨服务器访问压力小时执行

取得当前的时间减去一天获得前一天的年月日,以此获取前一天的数据总量的key,如:2017_07_31_count

取得总量后即可根据 年月日_编号 来获取所有的数据,如:2017_07_31_0、2017_07_31_1....2017_07_31_2000

把前一天所有数据进行统计并写入数据库,再将已记录到数据库的数据从redis中移除

 

 

=============================================================================


这样就基本完成了  用户在页面停留时长的记录。

当然还有很多缺陷,希望大佬们多多指正。

 

【ps:转载请注明出处】

以上是关于关于采集用户页面停留时长的一些思路的主要内容,如果未能解决你的问题,请参考以下文章

统计用户停留网站时长

面试题: LEAD 和 LAG 求每个用户的页面停留时长

面试题: LEAD 和 LAG 求每个用户的页面停留时长

面试题: LEAD 和 LAG 求每个用户的页面停留时长

那些年,加班搞过的需求...

互联网产品怎么做数据埋点