设为首页 收藏本站
查看: 874|回复: 0

[经验分享] 使用Redis做用户页面停留时长纪录的一些思路

[复制链接]
发表于 2017-12-21 13:41:22 | 显示全部楼层 |阅读模式
  最近两天想到,关于记录用户在页面停留时长的一些思路
  大概流程:
  进入页面后将当前时间和页面url发送的服务端,服务端创建唯一编号并记录后将唯一编号返回到客户端,
  客户端定时发送心跳到服务端更新最后浏览时间。
  服务端将记录的数据存储到redis中,每天凌晨通过定时任务来进行统计,将前一天的数据到数据库中,并移除redis中已记录到数据库中的数据
DSC0000.png

  客户端(浏览器):
  (全部采用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、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-426452-1-1.html 上篇帖子: redis实现分布式可重入锁 下篇帖子: php安装扩展步骤(redis)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表