kv存儲 - 怎樣用 Redis 緩存微博的評論列表?
問題描述
我不知道微博的評論是不是用了Redis緩存,我只是拿他來做為一個例子而已。通用的場景是:用Redis緩存有序的對象列表,要求可以對對象進行增、刪、查操作。
我以微博的評論來說,之前跟其它人交流時,是用zset或list。如果用zset,每個元素是評論id,評論時間做score,而評論的內(nèi)容無法存儲,只能根據(jù)id再查mysql等數(shù)據(jù)庫。如果用list,每個元素是一個hash的json序列化(包含評論id,評論內(nèi)容,評論時間等),這樣的話貌似沒有辦法實現(xiàn)根據(jù)評論id刪除評論了? 當然,list的元素也可直接用評論id,那這樣的話,其實跟用zset差不多。
不知道大家有沒有更好的方案實現(xiàn)“用Redis緩存有序的對象列表,要求可以對對象進行增、刪、查、分頁操作”
問題解答
回答1:如果用zset,每個元素是評論id,而評論的內(nèi)容無法存儲,只能根據(jù)id再查mysql等數(shù)據(jù)庫
zadd 微博 評論id 評論id+評論的內(nèi)容id做scope,可以用id刪除,后面的評論內(nèi)容也能顯示。
之前看到過這個問題,當時沒有回,因為你舉的例子看不太懂,隔了這么多天還沒人回你,我就來說一下吧,你的例子讓人看不太懂!上面的解決辦法也就只能是按你說的實際例子來說一下。
回答2:用list保存評論id,然后每條評論以id為key保存成hash。另外,一般還需要給這些鍵設置過期時間
相關文章:
1. html5和Flash對抗是什么情況?2. phpadmin的數(shù)據(jù)庫,可以設置自動變化時間的變量嗎?就是不需要接收時間數(shù)據(jù),自動變化3. 求救一下,用新版的phpstudy,數(shù)據(jù)庫過段時間會消失是什么情況?4. html - 爬蟲時出現(xiàn)“DNS lookup failed”,打開網(wǎng)頁卻沒問題,這是什么情況?5. mac里的docker如何命令行開啟呢?6. boot2docker無法啟動7. javascript - js 修改表格元素的,可以用DOM操作實現(xiàn)嗎?8. SublimeText3漢化版安裝9. mysql - 這句sql 為什么不能查詢出所有的 qdwyc_zlgs的信息,總是查出兩條?不是應該三條嗎?10. android - VideoView與百度Map沖突
