我們?cè)陧?xiàng)目中常常需要緩存需要分頁的數(shù)據(jù),有如下幾種思路,我們來對(duì)比一下各自優(yōu)劣
幾種思路:
每頁數(shù)據(jù)分別使用一個(gè)key緩存,各自設(shè)置過期時(shí)間,在數(shù)據(jù)請(qǐng)求時(shí)且緩存中沒有時(shí)進(jìn)行初始化,pageIndex和pageSize作為緩存key的一部分,比如: ? ? ?(推薦學(xué)習(xí):Redis視頻教程)
?key:cstm:list:${pageIndex}_${pageSize}
value:序列化(List
每頁數(shù)據(jù)分別使用一個(gè)key緩存,在數(shù)據(jù)有更新時(shí),主動(dòng)更新所有頁的數(shù)據(jù),pageIndex和pageSize作為緩存key的一部分,比如:
key:cstm:list:${pageIndex}_${pageSize}
value:序列化(List
使用有序集合緩存熱點(diǎn)數(shù)據(jù),排序條件作為分?jǐn)?shù),使用命令【ZRANGE key start stop [WITHSCORES]】實(shí)現(xiàn)分頁效果
key:cstm:zset:pageList
value:序列化(Customer)
優(yōu)劣分析:
第一種方式:在數(shù)據(jù)新增、刪除間隙初始化緩存會(huì)產(chǎn)生,數(shù)據(jù)重復(fù),或者遺漏,比如:在第一頁數(shù)據(jù)緩存完成后,數(shù)據(jù)有新增的話,在緩存第二頁數(shù)據(jù)時(shí),兩頁緩存數(shù)據(jù)會(huì)有重復(fù)
第二種方式:若數(shù)據(jù)更新頻繁,緩存數(shù)據(jù)會(huì)比較頻繁的更新
第三種方式:這種方式相對(duì)比較友好,需要在數(shù)據(jù)變化的同時(shí)維護(hù)緩存,并注意修剪列表長度
更多redis相關(guān)技術(shù)文章,請(qǐng)?jiān)L問Redis視頻教程欄目進(jìn)行學(xué)習(xí)!