Java实现排行榜基于Redis
本文最后更新于:2021年6月15日 晚上
前言
排行榜作为互联网应用中几乎必不可少的一个元素,其能够勾起人类自身对比的欲望,从而来增加商品的销量。排行榜的实现方式基本大同小异,大部分都基于 Redis 的有序集合 sorted set 来实现。不久前,负责开发一个活动,就有排行榜这个需求,笔者也使用 Redis 进行了实现。本文通过了商品销售排行榜这一模型,来进行演示。
需求
- 按照商品销量进行排行
- 可以获得指定商品的排名
- 显示实时销售动态情况
需求分析
分析需求,以上这些都可以通过 Redis 的有序集合相关命令进行实现,首先看一下使用到的具体 Redis 命令。
1 |
|
排行榜预览
按照需求开发,最后的效果如下:
以下通过 Java 代码实现。
通过 Java 实现排行榜
引入依赖
项目中使用到了 Redis,因此需要引入相关依赖,为了简明演示,这里没有使用 JedisPool。
1 |
|
开发逻辑
页面上点击一次购买按钮,则对该手机的销量加 1,同时将销售动态添加到队列当中
1
2jedis.zincrby(Constants.SALES_LIST, 1, String.valueOf(phoneId));
jedis.lpush(Constants.BUY_DYNAMIC, msg);获得排行榜
1
2// 按照scope升序排名,取出前五
jedis.zrevrangeWithScores(Constants.SALES_LIST, 0, 4);获得指定手机的排名情况
1
jedis.zrevrank(Constants.SALES_LIST, String.valueOf(phoneId));
获得销售动态,此处只取 3 条,同时队列只保存最新的 20 条动态
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16List<DynamicVO> dynamicList = new ArrayList<>();
for (int i = 0; i < 3; i++) {
String result = jedis.lindex(Constants.BUY_DYNAMIC, i);
if (StringUtils.isEmpty(result)) {
break;
}
String[] arr = result.split(Constants.separator);
long time = Long.valueOf(arr[0]);
String phone = arr[1];
DynamicVO vo = new DynamicVO();
vo.setPhone(phone);
vo.setTime(StringUtil.showTime(new Date(time)));
dynamicList.add(vo);
}
jedis.ltrim(Constants.BUY_DYNAMIC, 0, 19);因为排行榜这种实时性比较强的数据,更新比较快,个人觉得没有必要进行持久化,如果 Redis 的排行榜数据丢失,可以通过代码重新计算排行,通过 zadd 命令,重新添加到 Redis 中即可。
1
2
3
4
5Map<String, Double> map = new HashMap<>();
map.put("1", 4.0);
map.put("2", 2.0);
map.put("3", 3.0);
jedis.zadd(Constants.SALES_LIST, map);源码下载
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!