问题产生
公司业务遇到此场景:在前端分页展示数据时,为了让每个数据都有相同的几率被展示,每次分页展示数据时,都是随机展示的,并要求每一页之间数据不能重复;而且,优先展示最近三天的上传的数据,用户看完数据后,继续加载三天前又三天的数据。
此时大概率会有一会有以下痛点:
- 有用户一直传数据,就会出现这个用户数据占满一页;
- 越晚上传的数据曝光量会越好,越早上传的数据曝光量越差;
- 类似这种3天又3天数据如何加载?;
因此提出这个需求;数据需要随机分页出现。
问题分析与解决
分析一
遇到这种问题,单纯的使用数据库就不好使了,况且数据库本身就比较脆弱;因此,我想到引入第三方工具:redis,而其我们软件本身就使用redis;使用redis性能也会得到极大提升,主要用到redis list 的方法;
分析二
针对问题一,同一用户数据占满一页,以及问题二的解决办法;大脑跳出来的方法就是数据随机选择,这时我想到通过list洗牌的方法。
分析三
问题三,用户看完数据后继续加载后面的数据,类似【懒加载】;解决办法:当用户刷数据到最后一页的时候,就触发【懒加载】,数据追加到redis list里面。
实现步骤与部分代码
1. 查询三天的数据,把主键id list 洗牌放入redis list;
// 使用 package java.util.Collections;
/**
* Randomly permutes the specified list using a default source of
* randomness. All permutations occur with approximately equal
* likelihood.
*/
public static void shuffle(List<?> list) {
Random rnd = r;
if (rnd == null)
r = rnd = new Random(); // harmless race.
shuffle(list, rnd);
}
/**
* 追加Lisit
*
* @param key 关键字
* @param list 列表
* @param expireTime 有效期
* @return boolean
*/
public Boolean addAll(String key, List list, Long expireTime) {
try {
redisTemplate.opsForList().rightPushAll(key, list);