美文网首页
排行榜功能设计方案

排行榜功能设计方案

作者: 土卫十六 | 来源:发表于2018-03-09 15:24 被阅读0次

一般情况下,排行榜的实现都是在服务端接收到客户端请求后查库排序返回结果的一个过程,可能在一段时间内甚至永久性的,这批数据是不变的,查询到的结果是完全一致的,为了避免大量的资源浪费,可以考虑引入缓存。这里我们使用redis。

这样,我们在第一次查询top n的时候使用sql的排序,直接返回结果,同时把结果存redis。此时可以有两种方式,1.排序结果存string格式;2.排序结果存sorted set(有序集合),排序逻辑交给redis。后续的查询直接从redis获取返回结果,提高效率,节省资源。

这里先不考虑两种方式的优劣,继续往后进行。

方案一、定时更新
如果对结果的时效性要求不太严格,可以设置间隔一段时间查库并更新redis,每次取结果直接查redis。
当然,这种方案的劣势也很明显,1.不能实时,可能导致获取的排行榜不准确;2.如果这个赛事已经结束了,排行榜实际上已经是死数据了,这个时候还定时去更新的话就纯属多此一举了。

方案二、实时更新
第一次查询还是查库和存redis,后续从redis取数据。在比赛进行中,有序数据是变化的,这样就需要,在每次提交比赛数据可能会导致排行榜数据变动的时候,同步更新redis数据。上面说的,我们存redis的时候是可以有两种方式选择的:
如果我们存的是string格式,这里我们可以直接取到top n的数据转json以后直接覆盖redis里面的原数据,这样保证了数据的实时更新。
如果我们存的是有序集合,第一种方式:我们从redis里面取到排名倒数第一的数据,如果提交的数据大于取到的数据,这个数据就放到集合中。
第二种方式:我们从redis里面取到top n的数据,如果提交的数据大于top n中倒数第一的数据,这个数据就放到集合中。
很明显,第二种效率上可能会低一些,但是可能会节省一些空间,如何选择根据具体情况。

相关文章

  • 排行榜功能设计方案

    一般情况下,排行榜的实现都是在服务端接收到客户端请求后查库排序返回结果的一个过程,可能在一段时间内甚至永久性的,这...

  • [followme]如何写好软件设计文档实战系列-1

    案例一:幼儿园用户心理测评套餐设计方案 原始设计方案: 点评:原始设计方案,结构完整,实现方案功能OK。 会议评审...

  • 多人拼单购买功能产品设计方案

    题目: 请你为淘宝设计一个多人拼单购买的新功能。描述出这个功能的核心逻辑,以及基本的产品设计方案。 产品设计方案:...

  • 代码重构流程

    目录 重构功能名称 需求整理 需求评审 设计方案 设计评审 代码重构 重构验收 汇总意见 重构功能名称 待重构功能...

  • 0082 实现图书管理系统的公共图书查询功能

    上节课完成了费用查询功能。 这节课来完成公共图书库存查询功能。 编写图书热门排行榜和库存查询功能 热门排行榜主要是...

  • 培养数据分析能力

    数据需求: 功能设计方案 功能的设计目的、目标 功能上线后需要跟踪的数据指标、指标精确定义 作用:自我梳理。如果能...

  • 游戏排行榜设计

    前言 游戏排行榜是每个游戏都必备的一个功能。有日常常驻的排行榜,比如游戏的战力排行榜,游戏的财富排行榜等。还有就是...

  • [源码和文档分享]基于JSP实现的在线投票系统

    一、设计方案 1.1 投票系统的功能组成 投票系统功能有:选择投票和个人操作及设置,投票设置,投票结果分析,投票操...

  • [源码和文档分享]基于JSP实现的在线投票系统

    一、设计方案 1.1 投票系统的功能组成 投票系统功能有:选择投票和个人操作及设置,投票设置,投票结果分析,投票操...

  • 为淘宝设计拼购功能

    为淘宝设计一个多人拼单购买的新功能。描述出这个功能的核心逻辑,以及基本的产品设计方案。 思路:拼单功能对标到目前市...

网友评论

      本文标题:排行榜功能设计方案

      本文链接:https://www.haomeiwen.com/subject/lkipfftx.html