Event on key expire

2019-02-03 01:34发布

I wonder if there is a feature in redis that allow me to get all expired keys (I mean some kind of event, that gives me an opportunity to take back all expire records). The purpose of it is in saving old values into another database. I've heard that it's possible using publishing mechanism, but google can't help we with this idea.

3条回答
何必那么认真
2楼-- · 2019-02-03 02:07

The built-in expired event generated by keyspace notification is not accurate. See the last section of http://redis.io/topics/notifications

Keys with a time to live associated are expired by Redis in two ways:

  1. When the key is accessed by a command and is found to be expired.

  2. Via a background system that looks for expired keys in background, incrementally, in order to be able to also collect keys that are never accessed.

The expired events are generated when a key is accessed and is found to be expired by one of the above systems, as a result there are no guarantees that the Redis server will be able to generate the expired event at the time the key time to live reaches the value of zero. If no command targets the key constantly, and there are many keys with a TTL associated, there can be a significant delay between the time the key time to live drops to zero, and the time the expired event is generated.

To fully implement an accrue expire event, you might have to implement it by yourself. For example, by using a sorted list (or AVL tree) sorted by the expire time, and continuously reading the tail of list (unqueue). If the reader finds the the expire time hasn't been reached, it sleeps (expire time - now). In this way the accuracy can be controlled within 10s ms.

查看更多
来,给爷笑一个
3楼-- · 2019-02-03 02:13

Use redis-scheduler.
You can find it here

查看更多
\"骚年 ilove
4楼-- · 2019-02-03 02:27

Current development version of redis contains a new feature: keyspace notifications. Documentation: http://redis.io/topics/notifications

Keyspace notifications allows clients to subscribe to Pub/Sub channels in order to receive events affecting the Redis data set in some way.

Examples of the events that is possible to receive are the following:

  • All the commands affecting a given key.
  • All the keys receiving an LPUSH operation.
  • All the keys expiring in the database 0.

Hopefully, it will make it to stable soon.

BTW, it won't be very useful in helping you save values of expired keys. When expiration event is fired, the value is gone already.

查看更多
登录 后发表回答