七叶笔记 » 数据库 » 手把手教你用Redis 实现点赞功能并且与数据库同步

手把手教你用Redis 实现点赞功能并且与数据库同步

一、Redis 缓存设计及实现

Linux下安装Redis或者Docker下安装Redis并且启动(redis-server)

SpringBoot整合Redis

1.在 pom.xml 中引入依赖

2.在启动类上添加注释 @EnableCaching

3.编写 Redis 配置类 RedisConfig

二、点赞数据在 Redis 中的存储格式

用 Redis 存储两种数据: 一种是记录点赞人、被点赞人、点赞状态的数据一种是每个用户被点赞了多少次,做个简单的计数

由于需要记录点赞人和被点赞人,还有点赞状态(点赞、取消点赞),还要固定时间间隔取出 Redis 中所有点赞数据,所以 Redis 数据格式中 Hash 最合适。

因为 Hash 里的数据都是存在一个键里,可以通过这个键很方便的把所有的点赞数据都取出。这个键里面的数据还可以存成键值对的形式,方便存入点赞人、被点赞人和点赞状态。

设点赞人的 id 为 giveLikeId,被点赞人的 id 为 likeUserId ,点赞时状态为 1,取消点赞状态为 0。将点赞人 id 和被点赞人 id 作为键,两个 id 中间用 :: 隔开,点赞状态作为值。

类似于这样:

在service层操作Redis

实现类 RedisServiceImpl :

RedisKeyUtils, 用于根据一定规则生成 key

LikedStatusEnum 用户点赞状态的枚举类

三、数据库设计

数据库表中至少要包含三个字段:被点赞用户 id,点赞用户 id,点赞状态。再加上主键 id,创建时间,修改时间就行了。

对应的对象 UserLike

在service层操作数据库

LikedServiceImpl 实现类

四、开启定时任务持久化存储到数据库

这里使用的是定时任务 Quartz框架

1、 添加依赖

2、 编写配置文件

3、 编写执行任务的类继承自 QuartzJobBean

在定时任务中直接调用 LikedService 封装的方法完成数据同步。

五、注意事项

1.点赞 / 取消点赞 跟 点赞数 +1/ -1 应该保证是原子操作 ,不然出现并发问题就会有两条重复的点赞记录 , 所以要给整个原子操作加锁 。

2.同时需要在 Spring Boot 的系统关闭钩子函数中补充同步 redis 中点赞数据到 mysql 中的过程 . 不然有可能出现距离上一次同步 1 小时 59 分的时候服务器更新 , 把整整两小时的点赞数据都给清空了 。

到此这篇关于手把手教你用Redis 实现点赞功能并且与数据库同步的文章就介绍到这了,更多相关Redis 点赞内容请搜索七叶笔记以前的文章或继续浏览下面的相关文章希望大家以后多多支持七叶笔记!

相关文章