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

Pra*_*gam 0 python caching redis

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

但密钥设置为 180 秒或 3 分钟后过期。这有可能吗?此外,在第一次写入后,redis 密钥不会被写入/失效。

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)
Run Code Online (Sandbox Code Playgroud)

这是奇怪的行为吗?设置为更长的缓存,如 3600(1 小时)解决了我的问题,但想知道为什么 3 分钟的缓存会在 5 秒后过期......

谢谢

Bru*_*uno 5

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

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

docker pull redis
Run Code Online (Sandbox Code Playgroud)

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

docker run -d -p 6379:6379 redis:latest
Run Code Online (Sandbox Code Playgroud)

这里是 Python 代码,通过将缓存保留 180 秒,可以完美运行:

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")))
Run Code Online (Sandbox Code Playgroud)