Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

TTL for a set member

Is it possible in Redis to set TTL (time to live) not for a specific key, but for a member for a set?

I am using a structure for tags proposed by Redis documentation - the data are simple key-value pairs, and the tags are sets containing keys corresponding to each tag, e.g.

> SETEX id:id_1 100 'Lorem ipsum' OK > SADD tag:tag_1 id:id_1 (integer) 1 

The key id:id_1 will expire as expected but i don't see an efficient way to remove the corresponding member from the tag:tag_1 set.

One way I came up is using a cron job containing a script which would remove expired keys from sets periodically - by adding all the tag names to another set and then iterating through all the tags, then all the ids corresponding to each tag and checking if corresponding key exists - if not, calling SREM.

I don't think it will be an efficient way and I would possibly like to keep the tags as clean as possible, because the size of the sets will probably affect performance of searching by multiple tags (SINTER). Is there a more "internal" way?

like image 290
Przemek Avatar asked Jun 12 '13 08:06

Przemek


People also ask

Can we set TTL in Redis?

Redis TTL command is used to get the remaining time of key expiry in seconds. Returns the remaining time to live of a key that has a timeout. This introspection capability allows a Redis client to check how many seconds a given key will continue to be part of the dataset.

What is default TTL in Redis?

There is no default TTL. By default, keys are set to live forever.

What is Max TTL in Redis?

The max is 9223372036854775807 not 2147483647 for expire , try it.


2 Answers

No, this isn’t possible (and not planned either). The recommended approach is to use an ordered set with score set to timestamp and then manually removing expired keys. To query for non-expired keys, you can use ZRANGEBYSCORE $now +inf, to delete expired keys, ZREMRANGEBYSCORE -inf $now will do the trick.

In my application, I simply issue both commands every time I query the set. I also combine this with (long) expiration time on the set itself to eventually purge unused sets.

This article walks through it in more detail.

like image 133
Václav Slavík Avatar answered Oct 05 '22 08:10

Václav Slavík


It is not possible to directly expire items in list, sets, or zsets.

You need to implement a mechanism to be notified when the master item expires, so that you can maintain the corresponding sets accordingly.

See the answer to this question, I think it applies to your use case (replace session by id, and user by tag):

Redis, session expiration, and reverse lookup

like image 23
Didier Spezia Avatar answered Oct 05 '22 08:10

Didier Spezia