首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Redis缓存的过期时间比设置的过期时间快得多

Redis缓存的过期时间比设置的过期时间快得多
EN

Stack Overflow用户
提问于 2021-06-29 03:03:18
回答 1查看 242关注 0票数 0

当尝试使用python Redis包从缓存中读取时,它显示为已过期。这会在设置缓存的5秒内发生。但是,在5秒内的任何读取都有效。

但密钥被设置为在180秒或3分钟后过期。这是不是很有可能。此外,在第一次写入之后的任何时间,redis密钥都不会被写入/失效。

代码语言:javascript
复制
import redis
time_to_expire_s=180
client = redis.StrictRedis(host=self.host, port=self.port, password=self.password)
client.set(key, zlib.compress(value.encode('utf-8')), ex=time_to_expire_s)

就是这种奇怪的行为。设置一个更长的缓存,比如3600 (1小时)解决了我的问题,但想知道为什么3分钟的缓存会在5秒内过期……

谢谢

EN

回答 1

Stack Overflow用户

发布于 2021-06-29 06:37:44

我肯定会指向你正在运行的Redis服务器,它可能配置错误,下面我给你一个完整的工作示例,它使用docker并将缓存保留3分钟(或任何你想要的时间):

首先,假设您已经安装了docker:

代码语言:javascript
复制
docker pull redis

其次,运行容器并公开端口6379

代码语言:javascript
复制
docker run -d -p 6379:6379 redis:latest

这就是Python代码,它将缓存保留了180秒,从而完美地工作:

代码语言:javascript
复制
from redis.client import Redis
import random
import zlib

class Cache:
   def __init__(self):
      self.time_to_expire_s=180
      self.client = Redis(host="localhost", port=6379)
   def set_key(self, key, value):
      self.client.set(key, zlib.compress(value.encode('utf-8')), ex=self.time_to_expire_s)
   def get_key(self, key):
      return self.client.get(key)

if __name__ == "__main__":
   cache = Cache()
   rnd = random.Random()
   rnd_num=  rnd.randint(1,100)
   print(f"rdn {rnd_num}")
   if cache.get_key("MyCacheKey") is None:
      cache.set_key("MyCacheKey", "Myvalue"+str(rnd_num))
   else:
      print(zlib.decompress(cache.get_key("MyCacheKey")))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68168797

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档