Redis
 sql >> Database >  >> NoSQL >> Redis

Come impostare la scadenza della chiave hash in redis in base all'esistenza della chiave

NON PUOI ottenerlo con la pipeline, dal momento che non sai mai se la chiave è esistita fino a quando l'intera pipeline non è stata eseguita. Invece, puoi usare lo scripting Lua per fare il lavoro:

local key = KEYS[1]
local field = ARGV[1]
local value = ARGV[2]
local ttl = ARGV[3]

local exist = redis.call('exists', key)

redis.call('hset', key, field, value)

if exist == 0 then
    redis.call('expire', key, ttl)
end

Controlla questo per vedere come eseguire lo script Lua con redis-py. Quindi esegui lo script con la pipeline per ridurre il RTT .

AGGIORNAMENTO

Se insisti nell'usare WATCH per fare il lavoro, puoi provare il seguente codice:

with r.pipeline() as pipe:
    while 1:
        try:
            pipe.watch(hkey)

            exist = pipe.exists(hkey)

            pipe.multi()

            if not exist:
                pipe.hset(hkey, v, v)
                pipe.expire(hkey, 3600)
            else:
                pipe.hset(hkey, v, v)

            pipe.execute()
            break;
        except WatchError:
            continue