使用 Redis 缓存实现点赞和取消点赞的示例代码

 更新时间:2021年03月15日 10:44:04   作者:gnulxj  
这篇文章主要介绍了使用 Redis 缓存实现点赞和取消点赞的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

点赞功能是很多平台都会提供的一个功能,那么,我们要如何实现点赞和取消点赞呢?

这篇文章总结了我在项目中实现点赞的方法。

缓存 vs 数据库?

首先我们要考虑的是数据要放到哪里,很多时候我们都会把数据放到数据库(如 MySQL),由于关系型数据库的稳定性,大部分场景下我们也都会使用关系数据库来存储数据。

不过,在一些特殊的场景下,传统的关系型数据库很可能无法满足我们的需求。比如,在访问量较大的情况下,数据库很可能会宕机或者访问速度非常慢。这对用户来说是不能容忍的。因此就有了非关系型数据库,如 Redis 作为缓存,将数据放到内存中,实现数据的快速获取。下面我们就来看看如何使用 Redis 缓存实现点赞功能。

Redis 基本数据结构

数据结构 含义
string 字符串变量
list 链表
hash 映射表
set 无序集合
zset 有序集合

具体介绍可以参考这篇博客

点赞相关操作

  • 对帖子点赞
  • 对帖子取消点赞
  • 查看帖子点赞数

我们可以先定义一个接口,包含了点赞的相关操作:

public interface LikeCacheService {

 /**
  * 获取更新过的点赞帖子 id
  * @return
  */
 Set<Object> listUpdatedPost();

 /**
  * 测试用户是否已经对帖子点过赞
  * @param userId 点赞用户 id
  * @param postId 待测试帖子 id
  * @return true if user has liked post
  */
 boolean hasLiked(Integer userId, Long postId);

 /**
  * 获取帖子点赞数
  * @param postId 帖子 id
  * @return 帖子的点赞数
  */
 Integer getLikeCount(Long postId);

 /**
  * 点赞
  * @param uid 用户 id
  * @param pid 帖子 id
  */
 void like(Integer uid, Long pid);

 /**
  * 取消点赞
  * @param uid 用户 id
  * @param pid 帖子 id
  */
 void unlike(Integer uid, Long pid);

 /**
  * 某个帖子的点赞数 +1
  * @param pid 帖子 id
  */
 void incrLikedCount(Long pid);

 /**
  * 某个帖子的点赞数 -1
  * @param pid 帖子 id
  */
 void decrLikedCount(Long pid);

 /**
  * 删除某个帖子的点赞信息
  * @param pid 帖子 id
  */
 void deletePostLikeSet(Long pid);

 /**
  * 获取帖子点赞数据列表
  */
 List<FmsUserLikePost> listLikedData();

 /**
  * 获取帖子点赞数列表
  */
 List<FmsLikedCountDTO> listLikedCount();

 /**
  * 同步帖子点赞数据到数据库
  */
 void syncLikeDataToDatabase();
}

接下来,我们考虑一下要使用哪些数据结构来实现这些功能。

首先,点赞操作和取消点赞不能重复操作的,也就是不能连续点多次赞或者连续取消多次赞,每个用户只能对某帖子点一次赞,因此我们可以使用 set 来存储每个帖子的点赞用户,key 为帖子 id,value 为 每个对该帖子点赞的用户 id 集合。

  • 点赞:将点赞用户 id 加入对应帖子的点赞用户集
  • 取消点赞:将点赞用户 id 从对应帖子的点赞用户集移除

然后就是帖子点赞数的统计,由于每个帖子都对应一个点赞数,因此我们可以使用 hash 结构存储帖子的点赞数,key 为帖子 id,value 为该帖子的点赞数。

  • 点赞:对应 hash 结构的 value + 1
  • 取消点赞:对应 hash 结构的 value - 1

此外,为了保证数据的可恢复性,我们可以将 Redis 缓存中的数据定时写入关系型数据库中,进行数据持久化。

具体的实现代码可以参考这个项目的代码:FmsLikeCacheServiceImpl.java

到此这篇关于使用 Redis 缓存实现点赞和取消点赞的实现示例的文章就介绍到这了,更多相关Redis点赞和取消点赞内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 微服务链路追踪Spring Cloud Sleuth整合Zipkin解析

    微服务链路追踪Spring Cloud Sleuth整合Zipkin解析

    这篇文章主要为大家介绍了微服务链路追踪Spring Cloud Sleuth整合Zipkin解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • Java利用FileUtils读取数据和写入数据到文件

    Java利用FileUtils读取数据和写入数据到文件

    这篇文章主要介绍了Java利用FileUtils读取数据和写入数据到文件,下面文章围绕FileUtils的相关资料展开怎么读取数据和写入数据到文件的内容,具有一定的参考价值,徐娅奥德小伙伴可以参考一下
    2021-12-12
  • Spring boot @RequestBody数据传递过程详解

    Spring boot @RequestBody数据传递过程详解

    这篇文章主要介绍了Spring boot @RequestBody数据传递过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • java使用Abobe Acrobat DC生成模板

    java使用Abobe Acrobat DC生成模板

    这篇文章主要介绍了java使用Abobe Acrobat DC生成模板,文中有非常详细的代码示例,对正在学习java的小伙伴们有非常好的帮助,需要的朋友可以参考下
    2021-04-04
  • JAVA8之函数式编程Function接口用法

    JAVA8之函数式编程Function接口用法

    这篇文章主要介绍了JAVA8之函数式编程Function接口用法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • Java中dubbo+zookeeper微服务架构简介

    Java中dubbo+zookeeper微服务架构简介

    Apache Dubbo是一款高性能的 Java RPC 框架,这篇文章主要介绍了Java中dubbo+zookeeper微服务架构,需要的朋友可以参考下
    2021-09-09
  • SpringBoot最简洁的国际化配置

    SpringBoot最简洁的国际化配置

    这篇文章主要介绍了SpringBoot最简洁的国际化配置,Spring Boot是一个用于构建独立的、生产级别的Spring应用程序的框架,国际化是一个重要的功能,它允许应用程序根据用户的语言和地区显示不同的内容,在Spring Boot中,实现国际化非常简单,需要的朋友可以参考下
    2023-10-10
  • idea在工具栏中显示快速创建包和类的图标的详细步骤

    idea在工具栏中显示快速创建包和类的图标的详细步骤

    点击需要创建包或者类的位置,在点击对用的图标就可以快速创建类或者包了,下面小编给大家介绍idea在工具栏中显示快速创建包和类的图标的详细步骤,感兴趣的朋友一起看看吧
    2024-02-02
  • servlet的常见注册方式总结

    servlet的常见注册方式总结

    servlet大家都不陌生,当开发 Web 应用程序时,注册 Servlet 是一个常见的任务,本文将介绍一些常见的 Servlet 注册方法,希望对大家有所帮助
    2023-10-10
  • IntelliJ IDEA之配置JDK的4种方式(小结)

    IntelliJ IDEA之配置JDK的4种方式(小结)

    这篇文章主要介绍了IntelliJ IDEA之配置JDK的4种方式(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10

最新评论