Redis 保存扫码临时信息的一个案例

背景

最近对 Redis 有兴趣,故使用 Redis 来保存临时信息。
我们把业务关系简单地理解为:邀请、扫码、领券、设置偏好,直到登录系统成功为止。

本文所指的二维码,就是URL的一种变换。以邀请扫码页为例,URL:http://example.com/onepage.html?bid=$bid&sn=$sn

扫码领券设置偏好

B(Broker经纪人) C(客户) S(服务端) 备注
- - - -
出示二维码(B生成:Bid+Sn) 扫B码,跳转到领券页 - -
轮询S端BidSn BidSn存到S 接受轮询&存BidSn 接口7&8
设置C偏好,BidSnPref存到S 输入手机号,BidSnPhone存到S 存手机号&存C偏好 接口8&9

BidSn是一个线索,保存手机号、保存C偏好这两个动作,每个动作既不必然发生,也没有固定先后顺序。这些数据都是临时数据,只要扫码即可产生,因此选择存放到Redis中是合理的,在性能和数据上,可提供较好的体验。

Redis的数据变化过程

  1. Bid+Sn
  2. Bid+Sn+Phone
  3. Bid+Sn+bdcp(B-Defined-C-Pref)
  4. Bid+Sn+Phone+bdcp

注:完整的一个过程为1-2-4或者1-3-4。

Redis的数据结构

建议sorted sets,如下:
bid => [(sn => {phone, bdcp}), ...]
phone和bdcp,json格式存储,都不存在时,就是一个空的{}。

sn为score,{phone, bdcp} 为element

  1. 一个sn一个element:B和C是一对一服务时的场景。
  2. 一个sn多个elements:B和C是一对多服务时的场景,比如在案场多人扫描易拉宝情况。

第二种情况下,数据就退化为:
bid => [(sn => [{phone1}, {phone2}, ...]), ...]

参考Redis排序集的一个简单示例

转换数据

需要有一个合适的动作,触发临时数据到MySQl的转换。比如:C的下载登录可能就是一个合适的时机。注:elements 没有 bdcp 数据对于繁忙案场情况是普遍的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 转载地址:http://gnucto.blog.51cto.com/3391516/998509 Redis与Me...
    Ddaidai阅读 21,533评论 0 82
  • 源地址:http://blog.csdn.net/gjanuary/article/details/5207699...
    Freeasthew_a098阅读 1,585评论 0 6
  • 活动运营是指通过短期内开展活动,刺激用户活跃,完成相应kpi的一种运营方式,是三大运营中(用户运营,活动运营,内容...
    12_21阅读 667评论 0 2
  • 21天写作训练已圆满结束,可每天仍时时有个声音揪着心脏,时时在耳边吵着嚷着——“今天还没写东西呢!”,于是我终于受...
    Simmel阅读 312评论 0 0
  • 编辑:应天书院 本文转载自网络,版权归原创作者 【导言】: 这是一个真实的事情:两名高中男生围殴老师,还对着镜头嘶...
    小蜗牛有梦想阅读 17,002评论 0 2

友情链接更多精彩内容