控制Redis的hash的field中的過期時間
需求場景
在業(yè)務(wù)中有些數(shù)據(jù)因?yàn)闅v史原因用的hash
結(jié)構(gòu)存儲數(shù)據(jù),但是后期需求要求其中某個field
需要按照一些規(guī)則去過期,這個時候原來的邏輯懶得改,可以利用redis
的Zset
或者mq
的延時隊(duì)列去做過期設(shè)置.
方案一使用redis的Zset配置定時任務(wù)
撈個圖
demo需要清緩存的redis
的hash
結(jié)構(gòu)如下
然后我們再每次往Agent
這個hash
結(jié)構(gòu)存儲數(shù)據(jù)的時候,同時向AgentExpire
為key
的ZSET
數(shù)據(jù)結(jié)構(gòu)存儲一份數(shù)據(jù)(在存數(shù)據(jù)的時候可以在當(dāng)前時間上增加過期時間),這個數(shù)據(jù)的key
是hash
結(jié)構(gòu)中的field
的值,value
是過期時間戳(毫秒級)
如下圖所示:
然后用一個定時任務(wù)(我這里用的xxl-job,大家可以自己選擇)定時去掃描這個ZSET
里面score
小于當(dāng)前時間的元素,也就是使用ZSET
的rangeByScore
命令:
上面在向Zset
中存數(shù)據(jù)的時候已經(jīng)增加了過期時間,那么當(dāng)時間小于當(dāng)前時間時就過期了,代表hash
中對應(yīng)field
的數(shù)據(jù)要被delete
long currentTimeMillis = System.currentTimeMillis(); //掃描key為AgentExpire的zset中時間在 0~currentTimeMillis當(dāng)前時間范圍內(nèi)的數(shù)據(jù) Set<String> keys = redisTemplate.opsForZSet().rangeByScore("AgentExpire", 0, currentTimeMillis); //然后遍歷刪除即可 for (String key : keys) { Boolean hashResult = stringRedisTemplate.opsForHash().hasKey("xxxxxx", key); if(hashResult){ stringRedisTemplate.opsForHash().delete(recommenKey, key); stringRedisTemplate.opsForZSet().remove(SelectionRecommenAspect.selectionRecommendZset, key); } }
方案二使用mq延時隊(duì)列
延時隊(duì)列的配置可以參考我另一篇文章
http://www.dbjr.com.cn/article/273145.htm
在延時隊(duì)列消費(fèi)者處增加上述過期代碼即可
long currentTimeMillis = System.currentTimeMillis(); Set<String> expireKeys = //掃描key為AgentExpire的zset中時間在 0~currentTimeMillis當(dāng)前時間范圍內(nèi)的數(shù)據(jù) redisTemplate.opsForZSet().rangeByScore("AgentExpire", 0, currentTimeMillis);
綜上
使用zset
的話開發(fā)量少,但是定時job
一直刷容易浪費(fèi)資源,mq延時隊(duì)列
更精確
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Windows中Redis安裝配置流程并實(shí)現(xiàn)遠(yuǎn)程訪問功能
很多在windows環(huán)境中安裝Redis總是出錯,今天小編抽空給大家分享在Windows中Redis安裝配置流程并實(shí)現(xiàn)遠(yuǎn)程訪問功能,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-06-06redis實(shí)現(xiàn)存儲帖子的點(diǎn)贊狀態(tài)和數(shù)量的示例代碼
使用Redis來實(shí)現(xiàn)點(diǎn)贊功能是一種高效的選擇,因?yàn)镽edis是一個內(nèi)存數(shù)據(jù)庫,適用于處理高并發(fā)的數(shù)據(jù)操作,這篇文章主要介紹了redis實(shí)現(xiàn)存儲帖子的點(diǎn)贊狀態(tài)和數(shù)量的示例代碼,需要的朋友可以參考下2023-09-09Redis?key的過期時間和永久有效的實(shí)現(xiàn)
在Redis中,鍵可以設(shè)置過期時間或被永久保存,`EXPIRE`和`PEXPIRE`命令分別用于設(shè)置鍵的過期時間,具有一定的參考價值,感興趣的可以了解一下2024-09-09Redis實(shí)現(xiàn)消息的發(fā)布訂閱原理分析
本文主要介紹了Redis實(shí)現(xiàn)消息的發(fā)布訂閱原理分析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07Redis如何實(shí)現(xiàn)計(jì)數(shù)統(tǒng)計(jì)
這篇文章主要介紹了Redis如何實(shí)現(xiàn)計(jì)數(shù)統(tǒng)計(jì)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04詳解使用Redis SETNX 命令實(shí)現(xiàn)分布式鎖
本篇文章主要介紹了詳解使用Redis SETNX 命令實(shí)現(xiàn)分布式鎖,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01