您的位置:首页 > 数据库 > Redis

Redis存储商品热度

2022-05-31 22:58 3259 查看

项目中有一个需求,就是可以根据商品的热度进行排序

  • 起初想着使用string类型来存储如:

    sku:hotscore:商品的ID
    但是这回有个问题,当商品数量多了那k-v岂不是得炸了,维护起来也非常不方便

  • 推荐做法:使用Redis的ZSET类型

/**
* 给商品添加热度
*
* @param skuId
*/
@Override
public void incrHotScore(Long skuId) {
// 点击一次redis热度就+1
Double score = stringRedisTemplate.opsForZSet().incrementScore(RedisConstants.SKU_HOTSCORE,
skuId.toString(), 1);
if (score % 100 == 0) {
// 分数达到了100就保存到es一次,避免每次都连接es存储,浪费性能
searchFeignClient.updateHotScore(skuId, score.longValue());
}
}
/**
* 更新商品热度分
*
* @param skuId
* @param score
*/
@Override
public void updateHotScore(Long skuId, Long score) {

Optional<Goods> optional = goodsMapper.findById(skuId);
Goods goods = optional.get();
goods.setHotScore(score);
// 修改
goodsMapper.save(goods);
log.info("热度分已更新:{}", score);
}

结果

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: