Redis設(shè)置Hash數(shù)據(jù)類型的過(guò)期時(shí)間
在 Redis
中可以通過(guò) setex
或 expire
方式來(lái)設(shè)置 key
的過(guò)期時(shí)間。但是對(duì)于Hash
數(shù)據(jù)類型 Redis
是不支持的,所以我們需要使用“曲線救國(guó)”的方式去實(shí)現(xiàn) Hash
數(shù)據(jù)類型的過(guò)期時(shí)間。
即,先對(duì) Hash
數(shù)據(jù)類型賦值,然后再對(duì) Hash
數(shù)據(jù)類型的 key
設(shè)置一個(gè)過(guò)期時(shí)間,這樣就間接的實(shí)現(xiàn)了對(duì) Hash
數(shù)據(jù)類型的過(guò)期時(shí)間操作。
命令行操作示例:
root@k8s-master-01:~# redis-cli 127.0.0.1:6379> HSET name key value (integer) 1 127.0.0.1:6379> HGET name key "value" 127.0.0.1:6379> EXPIRE name 10 (integer) 1 127.0.0.1:6379> TTL name (integer) 9 127.0.0.1:6379> TTL name (integer) 8 127.0.0.1:6379> HGET name key "value" 127.0.0.1:6379> TTL name (integer) 0 127.0.0.1:6379> TTL name (integer) -2 127.0.0.1:6379> HGET name key (nil) 127.0.0.1:6379> exit root@k8s-master-01:~#
原理了解之后就可以通過(guò)代碼的方式實(shí)現(xiàn)對(duì) Hash
數(shù)據(jù)類型的過(guò)期時(shí)間操作,這里以 Python
偽代碼為例,其他語(yǔ)言都是相同原理。
def handle_data(self, data, db, time): list([value for value in map(lambda index: data.pop(index) if data.get(index) else None, self.blacklist)]) key = '%s:%s' % (self.redis_db[db], data['id']) for k, v in data.items(): k = self.handle_field(k) if v is None: v = '' if isinstance(v, list) or isinstance(v, dict): v = json.dumps(v) if isinstance(v, datetime.datetime): v = v.strftime("%Y-%m-%d %H:%M:%S") self.redis.hset(key, k, v) # 設(shè)置 Hash 數(shù)據(jù)類型 if time: self.redis.expire(key, time) # 設(shè)置 key 過(guò)期時(shí)間
到此這篇關(guān)于Redis設(shè)置Hash數(shù)據(jù)類型的過(guò)期時(shí)間的文章就介紹到這了,更多相關(guān)Redis Hash過(guò)期時(shí)間內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何使用gradle將java項(xiàng)目推送至maven中央倉(cāng)庫(kù)
本文主要介紹了使用gradle將java項(xiàng)目推送至maven中央倉(cāng)庫(kù),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09基于Redis實(shí)現(xiàn)雙加密Token的示例代碼
在現(xiàn)代分布式系統(tǒng)中,Token管理是身份驗(yàn)證和授權(quán)的核心部分,本文將深入分析一個(gè)基于Redis的Token管理實(shí)現(xiàn),探討其設(shè)計(jì)思路、關(guān)鍵代碼邏輯以及實(shí)現(xiàn)細(xì)節(jié),通過(guò)對(duì)源碼的逐層剖析,幫助讀者更好地理解Token管理的實(shí)現(xiàn)原理,需要的朋友可以參考下2025-01-01利用Redis?lua實(shí)現(xiàn)高效讀寫(xiě)鎖的代碼實(shí)例
這篇文章給大家介紹了如何利用Redis?lua實(shí)現(xiàn)高效的讀寫(xiě)鎖,讀寫(xiě)鎖的好處就是能幫助客戶讀到的數(shù)據(jù)一定是最新的,寫(xiě)鎖是排他鎖,而讀鎖是一個(gè)共享鎖,需要的朋友可以參考下2024-01-01Redis+AOP+自定義注解實(shí)現(xiàn)限流
這篇文章主要為大家詳細(xì)介紹了如何利用Redis+AOP+自定義注解實(shí)現(xiàn)個(gè)小功能:自定義攔截器限制訪問(wèn)次數(shù),也就是限流,感興趣的可以了解一下2022-06-06Redis中SDS簡(jiǎn)單動(dòng)態(tài)字符串詳解
Redis中的SDS(Simple?Dynamic?String)是一種自動(dòng)擴(kuò)容的字符串實(shí)現(xiàn)方式,它可以提供高效的字符串操作,并且支持二進(jìn)制安全。SDS的設(shè)計(jì)使得它可以在O(1)時(shí)間內(nèi)實(shí)現(xiàn)字符串長(zhǎng)度的獲取和修改,同時(shí)也可以在O(N)的時(shí)間內(nèi)進(jìn)行字符串的拼接和截取。2023-04-04Redis數(shù)據(jù)遷移RedisShake的實(shí)現(xiàn)方法
本文主要介紹了Redis數(shù)據(jù)遷移RedisShake的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04redisson中RRateLimiter分布式限流器的使用
Redisson Ratelimiter是Redisson框架中的一種限流算法,用于限制對(duì)資源的訪問(wèn)頻率,本文主要介紹了redisson中RRateLimiter分布式限流器的使用,感興趣的可以了解一下2024-06-06