孤独海岸线 发表于 2017-12-21 13:41:22

使用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:转载请注明出处】
页: [1]
查看完整版本: 使用Redis做用户页面停留时长纪录的一些思路