文章詳情頁
kv存儲 - 怎樣用 Redis 緩存微博的評論列表?
瀏覽:99日期:2022-06-25 17:55:17
問題描述
我不知道微博的評論是不是用了Redis緩存,我只是拿他來做為一個例子而已。通用的場景是:用Redis緩存有序的對象列表,要求可以對對象進行增、刪、查操作。
我以微博的評論來說,之前跟其它人交流時,是用zset或list。如果用zset,每個元素是評論id,評論時間做score,而評論的內容無法存儲,只能根據id再查mysql等數據庫。如果用list,每個元素是一個hash的json序列化(包含評論id,評論內容,評論時間等),這樣的話貌似沒有辦法實現根據評論id刪除評論了? 當然,list的元素也可直接用評論id,那這樣的話,其實跟用zset差不多。
不知道大家有沒有更好的方案實現“用Redis緩存有序的對象列表,要求可以對對象進行增、刪、查、分頁操作”
問題解答
回答1:如果用zset,每個元素是評論id,而評論的內容無法存儲,只能根據id再查mysql等數據庫
zadd 微博 評論id 評論id+評論的內容id做scope,可以用id刪除,后面的評論內容也能顯示。
之前看到過這個問題,當時沒有回,因為你舉的例子看不太懂,隔了這么多天還沒人回你,我就來說一下吧,你的例子讓人看不太懂!上面的解決辦法也就只能是按你說的實際例子來說一下。
回答2:用list保存評論id,然后每條評論以id為key保存成hash。另外,一般還需要給這些鍵設置過期時間
標簽:
微博
相關文章:
1. mysql - 在不允許改動數據表的情況下,如何優化以varchar格式存儲的時間的比較?2. css - chrome下a標簽嵌套img 顯示會多個小箭頭?3. css3 - 純css實現點擊特效4. docker網絡端口映射,沒有方便點的操作方法么?5. java中返回一個對象,和輸出對像的值,意義在哪兒6. mysql 為什么主鍵 id 和 pid 都市索引, id > 10 走索引 time > 10 不走索引?7. vim - docker中新的ubuntu12.04鏡像,運行vi提示,找不到命名.8. javascript - 有適合開發手機端Html5網頁小游戲的前端框架嗎?9. javascript - Img.complete和img.onload判斷圖片加載完成有什么區別?10. 推薦好用mysql管理工具?for mac和pc
排行榜
