本文基于SpringCloud,用户发起点赞、取消点赞后先存入Redis中,再每隔两小时从Redis读取点赞数据写入数据库中做持久化存储。
点赞功能在很多系统中都有,但别看功能小,想要做好需要考虑的东西还挺多的。
点赞、取消点赞是高频次的操作,若每次都读写数据库,大量的操作会影响数据库性能,所以需要做缓存。
至于多久从Redis取一次数据存到数据库中,根据项目的实际情况定吧,我是暂时设了两个小时。
项目需求需要查看都谁点赞了,所以要存储每个点赞的点赞人、被点赞人,不能简单的做计数。
文章分四部分介绍:
Redis缓存设计及实现
数据库设计
数据库操作
开启定时任务持久化存储到数据库
一、Redis缓存设计及实现1.1Redis安装及运行Redis安装请自行查阅相关教程。
说下Docker安装运行Redis
dockerrun-d-p:redis:4.0.8
如果已经安装了Redis,打开命令行,输入启动Redis的命令
redis-server1.2Redis与SpringBoot项目的整合
1.在pom.xml中引入依赖
dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-redis/artifactId/dependency
2.在启动类上添加注释
EnableCachingSpringBootApplicationEnableDiscoveryClientEnableSwagger2EnableFeignClients(basePackages="