• 使用Redis做用户页面停留时长纪录的一些思路


    最近两天想到,关于记录用户在页面停留时长的一些思路

    大概流程:

    进入页面后将当前时间和页面url发送的服务端,服务端创建唯一编号并记录后将唯一编号返回到客户端,

    客户端定时发送心跳到服务端更新最后浏览时间。

    服务端将记录的数据存储到redis中,每天凌晨通过定时任务来进行统计,将前一天的数据到数据库中,并移除redis中已记录到数据库中的数据


    客户端(浏览器):

    (全部采用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:转载请注明出处】

  • 相关阅读:
    Web性能优化系列(3):如何延迟加载JS
    Web性能优化系列(2):剖析页面绘制时间
    Web性能优化系列(1):Web性能优化分析
    页面制作之开发调试工具(1)
    格式化 SQL 来提高效率
    关于SQL注入,你应该知道的那些事
    jQuery()方法的第二个参数
    JSON简介以及用法代码汇总
    js简单的面试题
    常用meta整理
  • 原文地址:https://www.cnblogs.com/staneee/p/7267560.html
Copyright © 2020-2023  润新知