Redis設(shè)置Hash數(shù)據(jù)類型的過期時間
在 Redis
中可以通過 setex
或 expire
方式來設(shè)置 key
的過期時間。但是對于Hash
數(shù)據(jù)類型 Redis
是不支持的,所以我們需要使用“曲線救國”的方式去實現(xiàn) Hash
數(shù)據(jù)類型的過期時間。
即,先對 Hash
數(shù)據(jù)類型賦值,然后再對 Hash
數(shù)據(jù)類型的 key
設(shè)置一個過期時間,這樣就間接的實現(xiàn)了對 Hash
數(shù)據(jù)類型的過期時間操作。
命令行操作示例:
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:~#
原理了解之后就可以通過代碼的方式實現(xiàn)對 Hash
數(shù)據(jù)類型的過期時間操作,這里以 Python
偽代碼為例,其他語言都是相同原理。
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ān)于Redis設(shè)置Hash數(shù)據(jù)類型的過期時間的文章就介紹到這了,更多相關(guān)Redis Hash過期時間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis數(shù)據(jù)遷移RedisShake的實現(xiàn)方法
本文主要介紹了Redis數(shù)據(jù)遷移RedisShake的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04redisson中RRateLimiter分布式限流器的使用
Redisson Ratelimiter是Redisson框架中的一種限流算法,用于限制對資源的訪問頻率,本文主要介紹了redisson中RRateLimiter分布式限流器的使用,感興趣的可以了解一下2024-06-06