婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 基于redis實現(xiàn)的點贊功能設(shè)計思路詳解

基于redis實現(xiàn)的點贊功能設(shè)計思路詳解

熱門標簽:最簡單的百度地圖標注 地圖標注如何即時生效 百度商家地圖標注怎么做 竹間科技AI電銷機器人 西藏教育智能外呼系統(tǒng)價格 小紅書怎么地圖標注店 玄武湖地圖標注 太原營銷外呼系統(tǒng) 地圖標注費用

前言

點贊其實是一個很有意思的功能。基本的設(shè)計思路有大致兩種, 一種自然是用mysql等

數(shù)據(jù)庫直接落地存儲, 另外一種就是利用點贊的業(yè)務(wù)特征來扔到redis(或memcache)中, 然后離線刷回mysql等。

直接寫入Mysql

直接寫入Mysql是最簡單的做法。

做兩個表即可,

1、post_like

記錄文章被贊的次數(shù),已有多少人贊過這種數(shù)據(jù)就可以直接從表中查到;

2、user_like_post

記錄用戶贊過了哪些文章, 當打開文章列表時,顯示的有沒有贊過的數(shù)據(jù)就在這里面;

缺點

1、數(shù)據(jù)庫讀寫壓力大

熱門文章會有很多用戶點贊,甚至是短時間內(nèi)被大量點贊, 直接操作數(shù)據(jù)庫從長久來看不是很理想的做法。

redis存儲隨后批量刷回數(shù)據(jù)庫

redis主要的特點就是快, 畢竟主要數(shù)據(jù)都在內(nèi)存嘛;

另外為啥我選擇redis而不是memcache的主要原因在于redis支持更多的數(shù)據(jù)類型, 例如hash, set, zset等。

下面具體的會用到這幾個類型。

優(yōu)點

1、性能高

2、緩解數(shù)據(jù)庫讀寫壓力

其實我更多的在于緩解寫壓力, 真的讀壓力, 通過mysql主從甚至通過加入redis對熱點數(shù)據(jù)做緩存都可以解決,

寫壓力對于前面的方案確實是不大好使。

缺點

1、開發(fā)復(fù)雜

這個比直接寫mysql的方案要復(fù)雜很多, 需要考慮的地方也很多;

2、不能保證數(shù)據(jù)安全性

redis掛掉的時候會丟失數(shù)據(jù), 同時不及時同步redis中的數(shù)據(jù), 可能會在redis內(nèi)存置換的時候被淘汰掉;

不過對于我們點贊而已, 稍微丟失一點數(shù)據(jù)問題不大;

具體設(shè)計

Mysql設(shè)計

這一塊和寫入寫mysql是一樣的,畢竟是要落地存儲的。

所以還是同樣的需要post_like, user_like_post這兩表存儲文章被點贊的個數(shù)(等統(tǒng)計), 用戶對那些文章點了贊(取消贊)。

這兩表分別通過post_id, user_id進行關(guān)聯(lián)。

redis設(shè)計部分:

post_set

在redis中弄一個set存放所有被點贊的文章

post_user_like_set_{$post_id}

對每個post以post_id作為key, 搞一個set存放所有對該post點贊的用戶;

post_user_like_{$post_id}_{$user_id}

將每個用戶對每個post的點贊情況放到一個hash里面去, hash的字段就

隨意跟進需求來處理就行了。

為啥用hash

只所以用hash是因為完全可以用hash來存儲一個點贊的對象, 對應(yīng)數(shù)據(jù)庫的一行記錄。

當然有同學會說用key, value也可以, 將所有的數(shù)據(jù)序列化(json_encode等)

后全部放到value里面去。 反復(fù)序列化也是一個很大的開銷不是, hash可以很

方便的修改某個字段, 而序列化和反序列化的操作。

post_{$post_id}_counter

對每個post維護一個計數(shù)器, 用來記錄當前在redis中的點贊數(shù),

這里我們只用counter記錄尚未同步到mysql中的點贊數(shù)(可以為負), 每次

刷回mysql中時將counter中的數(shù)據(jù)和數(shù)據(jù)庫已有的贊數(shù)相加即可。

用戶點贊/取消贊

獲取user_id, post_id, 查詢該用戶是否已經(jīng)點過贊, 已點過則不允許再次點贊,

或者設(shè)計為前端允許用戶點, 只是后臺不重復(fù)計算;

這里需要注意的是用戶點贊的記錄可能在數(shù)據(jù)庫中, 也可能在緩存中, 所以查詢的時候

緩存和數(shù)據(jù)庫都要查詢, 緩存沒有再查詢數(shù)據(jù)庫。

將用戶的點贊/取消贊的情況記錄在redis中, 具體為:

1、寫入post_set

post_id寫入post_set

2、寫入post_user_like_set_{$post_id}

user_id寫入post_user_like_set_{$post_id}

3、寫入post_user_like_{$post_id}_{$user_id}

將用戶點贊數(shù)據(jù), 例如贊狀態(tài), post_id, user_id, ctime(操作時間), mtime(修改時間)寫入post_user_like_{$post_id}_{$user_id}

4、更新post_{$post_id}_counter

更新post_{$post_id}_counter, 這里的更新稍晚復(fù)雜一點, 需要和前面一樣先獲取當前用戶是否對這個post點過贊

如果點過, 并且本次是取消贊, counter減一, 如果沒點過, 本次是點贊, counter加一。

如果原來是取消贊的情況, 本次是點贊, counter加一。

同步刷回數(shù)據(jù)庫

循環(huán)從post_set中pop出來一個post_id至到空

    根據(jù){$post_id} , 每次從post_user_like_set_{$post_id}中pop出來一個user_id直到空

        根據(jù)post_id, user_id, 直接獲取對應(yīng)的hash表的內(nèi)容(post_user_like_{$post_id}_{$user_id}

        將hash表中的數(shù)據(jù)寫入user_like_post表中

        將post_{$post_id}_counter中的數(shù)據(jù)和post_like中的數(shù)據(jù)相加, 將結(jié)果寫入到post_like表中

頁面展示

1、查詢用戶點贊情況

前面已經(jīng)說過, 需要同時查詢redis和mysql

2、查詢post點贊統(tǒng)計

同樣需要查詢redis中的post_{$post_id}_counter和mysql的post_like表, 并將兩者相加

得到的結(jié)果才是正確的結(jié)果

總結(jié)

解決了mysql讀寫的問題

但沒有針對用戶量較大的場景考慮分表的設(shè)計, 可以考慮針對user_id或者post_id進行分表

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • SpringBoot+Vue+Redis實現(xiàn)單點登錄(一處登錄另一處退出登錄)
  • SpringBoot Redis配置Fastjson進行序列化和反序列化實現(xiàn)
  • SpringBoot集成Redisson實現(xiàn)分布式鎖的方法示例
  • springboot整合redis集群過程解析
  • springboot +redis 實現(xiàn)點贊、瀏覽、收藏、評論等數(shù)量的增減操作

標簽:廣東 景德鎮(zhèn) 澳門 香港 林芝 唐山 揚州 贛州

巨人網(wǎng)絡(luò)通訊聲明:本文標題《基于redis實現(xiàn)的點贊功能設(shè)計思路詳解》,本文關(guān)鍵詞  基于,redis,實現(xiàn),的,點贊,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《基于redis實現(xiàn)的點贊功能設(shè)計思路詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于基于redis實現(xiàn)的點贊功能設(shè)計思路詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 正定县| 大关县| 建瓯市| 大理市| 自治县| 岱山县| 奇台县| 宣汉县| 临清市| 元朗区| 黑山县| 吐鲁番市| 盐池县| 和林格尔县| 页游| 宁乡县| 清徐县| 永丰县| 类乌齐县| 柘荣县| 马关县| 伊宁市| 襄樊市| 梅州市| 正安县| 河源市| 绥宁县| 平塘县| 来宾市| 衡阳县| 闽清县| 余庆县| 巨野县| 东方市| 潞城市| 平顺县| 衢州市| 辰溪县| 华坪县| 西乌| 咸阳市|