核心思路
- 使用redis进行数据记录,保证服务响应速度。
- 记录数据库,晚上做一致性更新。
- 对于不需要判重的数据,可以把数据从redis中同步到mysql,记录统计数据。
- 对于需要判重的数据,需要将记录保存到数据库中。数据库保证持久性,redis保证了访问速度。
- 点赞和收藏,需要保证单个用户只能点击一次。用redis的set符合要求。
java实现
点赞功能
@RestController
@RequestMapping("/like")
public class LikeController {
@Autowired
private RedisTemplate<String, String> redisTemplate;
@GetMapping("/add")
public String addLike(@RequestParam String userId, @RequestParam String objectId) {
String key = "like:" + objectId;
long result = redisTemplate.opsForSet().add(key, userId);
return result > 0 ? "点赞成功" : "不能重复点赞";
}
@GetMapping("/delete")
public String deleteLike(@RequestParam String userId, @RequestParam String objectId) {
String key = "like:" + objectId;
long result = redisTemplate.opsForSet().remove(key, userId);
return result > 0 ? "取消点赞" : "未进行点赞";
}
@GetMapping("/count")
public long countLike(@RequestParam String objectId) {
String key = "like:" + objectId;
return redisTemplate.opsForSet().size(key);
}
}
收藏功能
@RestController
@RequestMapping("/favorite")
public class FavoriteController {
@Autowired
private RedisTemplate<String, String> redisTemplate;
@PostMapping("/add")
public String addFavorite(@RequestParam String userId, @RequestParam String objectId) {
String key = "favorite:" + userId;
long result = redisTemplate.opsForSet().add(key, objectId);
return result > 0 ? "收藏成功" : "不能重复收藏";
}
@PostMapping("/delete")
public String deleteFavorite(@RequestParam String userId, @RequestParam String objectId) {
String key = "favorite:" + userId;
long result = redisTemplate.opsForSet().remove(key, objectId);
return result > 0 ? "取消收藏" : "未进行收藏";
}
@GetMapping("/count")
public long countFavorite(@RequestParam String userId) {
String key = "favorite:" + userId;
return redisTemplate.opsForSet().size(key);
}
@GetMapping("/list")
public Set<String> listFavorite(@RequestParam String userId) {
String key = "favorite:" + userId;
return redisTemplate.opsForSet().members(key);
}
}