使用 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點贊和取消點贊內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 在Redis中如何保存時間序列數據詳解
- 面試分析分佈式架構Redis熱點key大Value解決方案
- Redis中一個String類型引發的慘案
- Redis數據類型string和Hash詳解
- Java手寫Redis服務端的實現