引言

在很多平台都可以看到自己的最近商品或文章的浏览记录,要么保持最近1000条记录(如知乎的最近浏览记录),要么是100条,那如何在不创建多余的表的情况下而直接用缓存达到这个目标呢?

基础要求极其思路

1.技术选型:redis2.在每次浏览的时候去缓存中记录这条记录的ID3.确保记录最大条数只能达到设置的阈值,比如10004.记录不能重复且按照时间倒序排序,举例:昨天浏览的记录,今天再次浏览时之前的记录删除,只保留今天浏览的记录和时间5.持久化,浏览记录持久存在


1.使用redis的zset,用户唯一ID作为key,用户访问记录ID作为value,访问时间作为分数score2.每次浏览记录向该用户集合中插入一条记录,插入前判断是否有旧的记录,有则删除,然后添加,每次插入的记录时间戳递增,借助zset本身的有序性,很容易实现查询排序翻转3.插入后获取总记录,如果大于阈值,则删除阈值之外更旧的记录,时间倒序

实现步骤

Stringkey="wangsr0001"; for(inti=0;i<200;i ){ TimeUnit.SECONDS.sleep(1L); StringrandomChineseName=RandomPersonInfoUtil.getRandomTelephoneNumber(); redisTemplate.opsForZSet().add(key,randomChineseName,System.currentTimeMillis()); }

/** *新阅读记录插入 *@authorwjl */ @Test publicvoidinsertTest(){ //key Stringkey="wangsr0001"; //阈值 longtop=200; //新访问记录ID Stringvalue="15646051140"; Doublescore=redisTemplate.opsForZSet().score(key,value); //检索是否有旧记录1.无则插入记录值2.有则删除再次插入 if(null!=score){ //删除旧的 redisTemplate.opsForZSet().remove(key,value); } //加入新的记录,设置当前时间戳为分数score redisTemplate.opsForZSet().add(key,value,System.currentTimeMillis()); //获取总记录数 LongaLong=redisTemplate.opsForZSet().zCard(key); if(aLong>top){ //获取阈值200之后的记录(0,1]并移除 redisTemplate.opsForZSet().removeRange(key,0,aLong-top-1); } }

/** *列表查询 *@authorwjl */ @Test publicvoidscanTest(){ Stringkey="wangsr0001"; longstart=1; longsize=10; Set<ZSetOperations.TypedTuple>scoreWithScores=redisTemplate.opsForZSet().reverseRangeWithScores(key,start-1,size-1); Iterator<ZSetOperations.TypedTuple>iterator=scoreWithScores.iterator(); BigDecimalbigDecimal=null; while(iterator.hasNext()){ ZSetOperations.TypedTuplenext=iterator.next(); bigDecimal=BigDecimal.valueOf(next.getScore()); System.out.println("==》ID:" next.getValue() "时间:" bigDecimal.toPlainString()); } }

知乎怎么只看问答不看文章(如何实现类似知乎的功能查看最近1000条记录呢)(1)

知乎怎么只看问答不看文章(如何实现类似知乎的功能查看最近1000条记录呢)(2)

最后

#程序员##知乎##历史记录##缓存#

,